程序员人生 网站导航

30个你 “ 不可能全部会做 ” 的javascript题目

栏目:htmlcss时间:2015-07-27 08:05:38
1,以下表达式的运行结果是:
["1","2","3"].map(parseInt)
A.["1","2","3"]
B.[1,2,3]
C.[0,1,2]
D.其他
==============答案:D,parseInt第2个参数范围是:2⑶2,如果传入0,则默许依照10处理。请自己查看parseInt函数定义

2,以下表达式的运行结果是:
[typeof null, null instanceof Object]
A.["object",false]
B.[null,false]
C.["object",true]
D.其他

================答案:A,关于instanceof的深入讲授请参考:http://www.ibm.com/developerworks/cn/web/1306_jiangjj_jsinstanceof/

3,以下表达式的运行结果是:
[[3,2,1].reduce(Math.pow),[].reduce(Math.pow)]
A.报错
B.[9,0]
C.[9,NaN]
D.[9,undefined]

===================答案:A,空数组用reduce会报错,由于reduce在没有传入initValue时,会使用数组第1个元素做initValue,但是空数组没有第1个元素
4,以下表达式的运行结果是:
var val = "value";
console.info("Value id "+(val === "value")?"Something":"Nothing");
A.Something
B.Nothing
C.NaN
D.其他

===========答案:A,JS的比较分为两种,值类型比较和援用类型比较。值类型只比较值相等
5,以下表达式的运行结果是:
var name = "World";
(function(){
if(typeof name === "undefined"){
var name = "Jack";
console.info("Goodbye "+ name);
}else{
console.info("Hello " + name);
}
})();
A.Goodbye Jack
B.Hello Jack
C.Goodbye undefined
D.Hello undefined

=============答案:A,JS的变量作用于只有全局和函数级别,然后var声明的变量会有1个hoisting的进程
6,以下表达式的运行结果是:
var START = END ⑴00;
var count = 0;
for(var i = START ; i <= END ;i++){
count ++;
}
console.info(count);
A.0
B.100
C.101
D.其他
================答案:D,会报错,END未定义

7,以下表达式的运行结果是:
var arr = [0,1,2];
arr[10] = 10;
arr.filter(function(x){return x === undefined});
A.[undefined x 7]
B.[0,1,2,10]
C.[]
D.[undefined]

=============答案:C,filter不会处理数组中undefined的元素
8,以下表达式的运行结果是:
var two = 0.2;
var one = 0.1;
var eight = 0.8;
var six = 0.6;
[two -one == one,eight- six == two];
A.[true,true]
B.[false,false]
C.[true,false]
D.其他

==========答案:C,不知道为啥。结果为0.1和0.2浮点数会有区分?求解答
9,以下表达式的运行结果是:
function showCase(value){
switch(value){
case "A":
console.info("Case A");
break;
case "B":
console.info("Case B");
break;
case undefined :
console.info("undefined");
break;
default:
console.info("Do not know!");
}}
showCase(new String("A"));
A.Case A
B.Case B
C.Do not know
D.undefined

=============答案:C,switch使用===进行比较
10,以下表达式的运行结果是:
function showCase(value){
switch(value){
case "A":
console.info("Case A");
break;
case "B":
console.info("Case B");
break;
case undefined :
console.info("undefined");
break;
default:
console.info("Do not know!");
}}
showCase(String("A"));
A.Case A
B.Case B
C.Do not know
D.undefined

=============和上题重复
11,以下表达式的运行结果是:
function isOdd(num){
return num % 2 == 1;
}
function isEven(num){
return num % 2 == 0;
}
function isSane(num){
return isEven(num)||isOdd(num);
}
var values = [7,4,"13",⑼,Infinity];
values.map(isSane);
A.[true,true,true, true,true]
B.[true,true,true,true,false]
C.[true,true,true,false,false]
D.[true,true,false,false,false]

===================答案:C,负数求余为负数
12,以下表达式的运行结果是:
[parseInt(3,8),parseInt(3,2),parseInt(3,0)]
A.[3,3,3]
B.[3,3,NaN]
C.[3,NaN,NaN]
D.其他

============答案:D,[3, NaN, 3],参考第1题解答
13,以下表达式的运行结果是:
Array.isArray(Array.prototype)
A.true
B.false
C.报错
D.其他

==================答案:A

14,以下表达式的运行结果是:
var a = [0];
if([0]){
console.info(a == true);
}else{
console.info("else");
}
A.true
B.false
C."else"
D.其他
==============答案:B,数组是援用类型,用==比较是不是是同1个对象

15,以下表达式的运行结果是:
[]==[]
A.true
B.false
C.报错
D.其他

============答案:B,参考上1题

16,以下表达式的运行结果是:
[("5"+3),("5"⑶)]
A.["53",2]
B.[8,2]
C.报错
D.其他

==============答案:A,无需解释

17,以下表达式的运行结果是:
1+-+++-+1
A.true
B.false
C.报错
D.其他
==============答案:C,变态的题
18,以下表达式的运行结果是:
var arr = Array(3);
arr[0] = 2
arr.map(function(elem){return "1";});
A.[2,1,1]
B.["1","1","1"]
C.[2,"1","1"]
D.其他

===============答案:D,map不处理undefined的元素。结果应当是:["1",undefined,undefined]
19,以下表达式的运行结果是:
function sidEffecting(arr){
arr[0] = arr[2];
}
function bar(a,b,c){
c = 10;
sidEffecting(arguments);
return a+b+c;
}
bar(1,1,1);
A.3
B.12
C.报错
D.其他

=============答案:21,自己想去

20,以下表达式的运行结果是:
var a = 111111111111111110000;
b = 1111;
console.info(a+b);
A.111111111111111111111
B.111111111111111110000
C.NaN
D.Infinity

===================答案:B,不知道具体缘由,猜想整数越界?
21,以下表达式的运行结果是:
ar x = [].reverse;
x();
------分隔线----------------------------
------分隔线----------------------------

最新技术推荐