InterestingJavaScript
1.声明提升
写出下⾯代码的运⾏结果
var a,b;
(function(){
console.log(a);
console.log(b);
var a=b=3;
console.log(a);
console.log(b);
})();
console.log(a);
console.log(b);
A. undefined,undefined,3,3,undefined,3
B. undefined,undefined,3,3,undefined,undefined
C. 0,0,3,3,undefined,undefined
D. undefined,undefined,3,3,0,0
正确答案:A
解释:代码相当于下⾯这样的过程
var a,b;
(function(){
var a;
console.log(a); //undefined
console.log(b); //undefined
a=3;
b=3;
console.log(a); //3
console.log(b); //3
})();
console.log(a); //undefined
console.log(b); //3
2.变量定义规则
下⾯符合⼀个有效的javascript变量定义规则的是?
A. _ t2
B. with
C. a bc
D. 2a
正确答案: A
考点:ECMAScript语法
解析:with为关键字,空格不⾏,数字开头的不⾏
ElementById和ElementsByTagName
JavaScript中ElementById的返回值的类型和ElementsByTagName的返回值类型分别是?
A. Array,NodeList
B. Object, HTMLCollection
C. String,NodeList
D. Function,NodeList
正确答案: B
解析:这题可能有争议,浏览器测试代码如下
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Id与TagName类型检测</title>
</head>
<body>
<div id="test"></div>
<script type="text/javascript">
function checkType(element){
console.log(String.call(element));
}
ElementById('test')); //[object HTMLDivElement]
ElementsByTagName('div')); //[object HTMLCollection]
</script>
</body>
</html>
4.if/var
下⾯关于块内函数的做法哪些是正确的?
A. if(x){ function foo(){}}
B. if(x){ var function foo(){}}
C. if(x){ foo = function(){}}
D. ECMAScript明确的规范了块级函数,JavaScript实现了这个规范
正确答案:B
解析:测试报错
5.hasOwnProperty
下列代码
var obj={}
obj.hasOwnProperty("val");
中hasOwnProperty的作⽤是?
A. 判断obj对象是否具有val的属性
B. 判断obj对象是否具有val的值
C. 判断obj的原型对象是否具有val的属性
D. 判断obj的原型对象是否具有val的值
正确答案:A
解析:hasOwnProperty()函数⽤于指⽰⼀个对象⾃⾝(不包括原型链)是否具有指定名称的属性。如果有,返回true,否则返回false 6.call和apply
下⾯有关JavaScript中 call和apply的描述,错误的是?
A. call和apply都属于Function.prototype的⽅法,所以每个function实例都有call,apply属性
B. 两者传递的参数不⼀样,call函数第⼀个参数都是传⼊给当前对象的对象,apply不是
C. apply传⼊的是⼀个参数数组,也就是将多个参数组合成为⼀个数组传⼊
D. call传⼊的则是直接的参数列表。call⽅法可将⼀个函数的对象上下问从出事的上下⽂改变为thisObj指定的新对象。
正确答案:B
解析:apply和call都是改变函数内部this指向的⽅法,挂载在Function.prototype下
7.script标签
(不定项选择题)给⽹页添加javascript的⽅式有
A. 使⽤script标签,将JavaScript代码写到<script></script>之间
B. 添加外部javascript⽂件
C. 使⽤⾏内javascript
D. 使⽤@import引⼊javascript⽂件
正确答案:A,B,C
正则匹配到第一个关键字就停止
解析:只有CSS可以⽤@import⽅法,题⽬其实可以换成CSS,则全部正确
A. 使⽤style标签,将JavaScript代码写到<style></style>之间
B. 添加外部css⽂件
C. 使⽤⾏内css
D. 使⽤@import引⼊css⽂件
8.parseInt与map
[“1”, “2”, “3”].map(parseInt)的输出结果是
A. [1,NaN,NaN]
B. [1,2,3]
C. [NaN,NaN,NaN]
D. 发⽣错误
正确答案: A. [1,NaN,NaN]
解析:
Array.prototype.map(func(currentValue, index, arrary),thisObj)
map接受两个参数, ⼀个回调函数 callback, ⼀个回调函数的this值。其中回调函数接受三个参数currentValue, index, arrary
parseInt 只接受两个两个参数 string, radix(基数).基数。该值介于 2 ~ 36 之间,如果该参数⼩于 2 或者⼤于 36,则 parseInt() 将返回 NaN。如果为0,则直接输出字符串如下的例⼦来看this的运⽤和基数的例⼦:
var obj = {
value:1
};
["1", "2", "3"].map(function(currentValue, index, arrary){
console.log(this); //输出3次obj
},obj);
console.log(parseInt('1', 0)); //1
console.log(parseInt('123', 0)); //123
console.log(parseInt('2', 1)); //NaN
console.log(parseInt('3', 2)); //NaN
当["1", "2", "3"].map(parseInt)的时候,传⼊parseInt的参数为currentValue,index
9.Function.prototype.name
function foo() { }
var oldName = foo.name;
foo.name = "bar";
console.log([oldName, foo.name]);
A. [‘foo’,’bar’]
B. [‘foo’,’foo’]
C. [‘bar’,’bar’]
D. [‘bar’,’foo’]
答案:B.[‘foo’,’foo’];
函数的name属性指向函数名,挂载在Function.prototype下,所以不要给函数赋值属性name哈。并且这个属性是不可改变的.
所以下⾯这样的例⼦就不要出现了
function foo() {}
foo.name = "bar"; //bad,你居然真忘了Function.prototype.name是⼀个不可修改的属性!!
测试代码:
console.log(Function.prototype.hasOwnProperty('name')); //true
10.正则test⽅法的参数问题
var lowerCaseOnly =  /^[a-z]+$/;
[st(null), st()]
A. false, true
B. false,true
C. true,true
D. true,false
答案: C.true, true
如题所⽰,test⽅法如果参数为null或者不屑,则默认返回true
11.变量作⽤域
写出这段代码的运⾏结果
<SCRIPT type="text/javascript">
var bb = 1;
function aa(bb) {
bb = 2;
console.log(bb);
};
aa(bb);
console.log(bb);
</SCRIPT>
正确答案: 2 1
12.+-操作符
如下代码输出的结果是什么:
console.log(1+ "2"+"2");
console.log(1+ +"2"+"2");
console.log("A"- "B"+"2");
console.log("A"- "B"+2);
正确答案:
122 //数字与字符串+则数字默认转换为字符串
32 //+号会将字符串2先转化为数字,这种也是常⽤的将字符串转换为数字的⽅式
NaN 2
NaN
解析:插播——常见的将字符串转换为数字的⽅法:
parseInt,具体使⽤请看前⾯第8题
+"123"类似这种写法,⽐如某个参数不确定是不是数字可以这样+data.len
Number⽅法
从带宽(精简压缩后)考虑会⽤第⼆种,所以通常会在代码上⼤量看到这种写法
13.null和Object的关系
[typeof null, null instanceof Object]的输出结果是
正确答案:object, false
解析:
null为⼀个空的对象,这个对象存在但是⾥⾯⼀点东西都没有,相当于有堆空间但是⾥⾯没有属性。⽽undefined可以理解
为连堆空间都没有(⾄少表现出来是这样的不是吗?)null instanceof Object为false是因为null连属性都没有,更没有检测原型链的_proto_和prototype了。
14.+运算符优先于?:运算符
var val = ‘smtg’;
console.log(‘Value is ’ + (val === ‘smtg’) ? ‘Something’ : ‘Nothing’);
正确答案: ‘Something’
15.变量作⽤域
写出下⾯代码的执⾏效果
var name = 'World!';
(function () {
if (typeof name === 'undefined') {
var name = 'Jack';
console.log('Goodbye ' + name);
} else {
console.log('Hello ' + name);
}
})();
正确答案: Goodbye Jack
编译语法分析后代码(声明提升)如下
var name = 'World!';
(function() {
var name;
if (typeof name === 'undefined') {
name = 'Jack';
console.log('Goodbye ' + name); //Goodbye Jack
} else {
console.log('Hello ' + name);
}
})();
16.
写出下⾯题的答案
var END = Math.pow(2, 53);
var START = END - 100;
var count = 0;
for (var i = START; i <= END; i++) {
count++;
}
console.log(count);
正确答案:不会输出,因为END是最⼤值了,
解析:在 JS ⾥, Math.pow(2, 53) == 9007199254740992是可以表⽰的最⼤值. 最⼤值加⼀还是最⼤值. 所以循环不会停
17.浮点数的不准确性
输出0.1+0.2 === 0.3的结果,并简单地解释。
解析:经典的题⽬,浮点数因为存在误差,所以不能⽤===判定,通常在⾦额处理的时候会乘以10/100倍来⼩数部分的数据
18.正则表达式replace的⾼级⽤法
写出答案
"1 2 3".replace(/\d/g, parseInt)
答案:1, NaN, 3
解析:replace()⽅法的参数第⼆个参数可以是函数⽽不是字符串。在这种情况下,每个匹配都调⽤该函数,它返回的字符串将作为替换⽂本使⽤。
1.该函数的第⼀个参数是匹配模式的字符串
2.接下来的参数是与模式中的⼦表达式匹配的字符串,可以有 0 个或多个这样的参数
3.接下来的参数是⼀个整数,声明了匹配在 stringObject 中出现的位置
4.最后⼀个参数是 stringObject 本⾝。
题⽬中因为没有⼦表达式匹配,即()括起来的匹配项,所以传⼊parseInt的参数三次分别为:
parseInt("1", 0) //1,因为当基数为0时候直接输出第⼀个参数
parseInt("2",2) //NaN,因为2进制只有01两个数字
parseInt("3",4) //3,因为不超过四进制的最⼤值4

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。