JavaScript Perfection kill 测试及答案

下面是选择题:官方地址是 http://perfectionkills.com/javascript-quiz/


代码如下:

1.
(function(){
return typeof arguments;
})();
“object”
“array”
“arguments”
“undefined”
2.
var f = function g(){ return 23; };
typeof g();
“number”
“undefined”
“function”
Error
3.
(function(x){
delete x;
return x;
})(1);
1
null
undefined
Error
4.
var y = 1, x = y = typeof x;
x;
1
“number”
undefined
“undefined”
5.
(function f(f){
return typeof f();
})(function(){ return 1; });
“number”
“undefined”
“function”
Error
6.
var foo = {
bar: function() { return this.baz; },
baz: 1
};
(function(){
return typeof arguments[0]();
})(foo.bar);
“undefined”
“object”
“number”
“function”
7.
var foo = {
bar: function(){ return this.baz; },
baz: 1
}
typeof (f = foo.bar)();
“undefined”
“object”
“number”
“function”
8.
var f = (function f(){ return "1"; }, function g(){ return 2; })();
typeof f;
“string”
“number”
“function”
“undefined”
9.
var x = 1;
if (function f(){}) {
x += typeof f;
}
x;
1
“1function”
“1undefined”
NaN
10.
var x = [typeof x, typeof y][1];
typeof typeof x;
“number”
“string”
“undefined”
“object”
11.
(function(foo){
return typeof foo.bar;
})({ foo: { bar: 1 } });
“undefined”
“object”
“number”
Error
12.
(function f(){
function f(){ return 1; }
return f();
function f(){ return 2; }
})();

Error (e.g. “Too much recursion”)
undefined
13.
function f(){ return f; }
new f() instanceof f;
true
false
14.
with (function(x, undefined){}) length;

undefined
Error

下面是个人的解答:

代码如下:

// Q1
(function(){
return typeof arguments; //很显然这里应该返回的是 "object"
})();
// Q2
var f = function g(){ return 23; };
typeof g(); //在ie下,这里返回的是 "number",但是在ff下,却是Error(g未定义)
// Q3
(function(x){
delete x; //应该说局部变量是不能被delete的
return x; //所以这里返回1
})(1);
/*
赠送:
delete与变量,有以下关系:
1、对象预定义的属性是不能被delete的;2、通过prototype指定的属性是不能delete的
//关于2,可以理解成只能删除动态附加给对象实例的属性?
3、var定义的(我个人理解是局部变量)是不能被delete的;4、function定义的变量及参数(相当于局变量)是不能被删除的。
关于delete的介绍,这里有:http://tech.idv2.com/2008/01/09/javascript-variables-and-delete-operator/
*/
// Q4
var y = 1, x = y = typeof x;
x; //很显然,x应该是undefined
// Q5
(function f(f){
return typeof f(); //这里的f指的是传进来的匿名函数,因此应该是 "number" (也就是1)
})(function(){ return 1; });
// Q6
var foo = {
bar: function() { return this.baz; },
//但是,调用后,这里的this指向了bar,而bar是没有baz属性的,因此是undefined
baz: 1
};
(function(){
return typeof arguments[0](); //arguments[0]是foo.bar
})(foo.bar);
// Q7
var foo = {
bar: function(){ return this.baz; }, //同第6题
baz: 1
}
typeof (f = foo.bar)();
// Q8
var f = (function f(){ return "1"; }, function g(){ return 2; })();
//js的,号操作符,被调用的是第2个函数,因此返回的是"number"
typeof f;
// Q9
var x = 1;
if (function f(){}) {
x += typeof f; //ie下是 1function、ff下是1undefined
}
x;
// Q10
var x = [typeof x, typeof y][1]; //x="undefined"
typeof typeof x; //x是字符串,因此应该是 "string"
// Q11
(function(foo){
return typeof foo.bar;
//非常隐暗的一道题,参数foo指向的是传进来的json对象,而json对象又有个foo属性。
//因此,此处如果是 typeof foo.foo.bar的话就是"number"
//但,参数foo本身是没有bar属性的,因此是 "undefined"
})({ foo: { bar: 1 } });
// Q12
(function f(){
function f(){ return 1; }
return f(); // 函数定义,后者覆盖前者,因此是 2
function f(){ return 2; }
})();
// Q13
function f(){ return f; }
new f() instanceof f;
//new f()实际上和f是同一个东西,都是function,因此,两者是==,因此是false
//如果function f(){return 1;},那么返回的是object
// Q14
with (function(x, undefined){}) length;
//这样写就明白了 with(function(x,undefined){}){length;}
//而length,指是的function的形参个数,因此是 2

(0)

相关推荐

  • JavaScript Perfection kill 测试及答案

    下面是选择题:官方地址是 http://perfectionkills.com/javascript-quiz/ 复制代码 代码如下: 1. (function(){ return typeof arguments; })(); "object" "array" "arguments" "undefined" 2. var f = function g(){ return 23; }; typeof g(); "nu

  • javascript 翻页测试页(动态创建标签并自动翻页)

    翻页测试页 $(id).scrollHeight - $(id).offsetHeight) { moveto = $(id).scrollHeight - $(id).offsetHeight; } if(Math.abs($(id).scrollTop - moveto) $(id).scrollHeight - $(id).offsetHeight) { moveto = $(id).scrollHeight - $(id).offsetHeight; } scrollTo(id,move

  • 详解JavaScript的BUG和错误

    计算机程序中的缺陷通常称为 bug. 它让程序员觉得很好,将它们想象成小事,只是碰巧进入我们的作品. 实际上,当然,我们自己把它们放在了那里. 如果一个程序是思想的结晶,你可以粗略地将错误分为因为思想混乱引起的错误,以及思想转换为代码时引入的错误. 前者通常比后者更难诊断和修复. 语言 计算机能够自动地向我们指出许多错误,如果它足够了解我们正在尝试做什么. 但是这里 JavaScript 的宽松是一个障碍. 它的绑定和属性概念很模糊,在实际运行程序之前很少会发现拼写错误. 即使这样,它也允许你做

  • C# javaScript函数的相互调用

    问: 1.如何在JavaScript访问C#函数? 2.如何在JavaScript访问C#变量? 3.如何在C#中访问JavaScript的已有变量? 4.如何在C#中访问JavaScript函数? 问题1答案如下: javaScript函数中执行C#代码中的函数: 方法一:1.首先建立一个按钮,在后台将调用或处理的内容写入button_click中; 2.在前台写一个js函数,内容为document.getElementById("btn1").click(); 3.在前台或后台调用

  • 向大师们学习Javascript(视频与PPT)

    Douglas Crockford:Douglas Crockford是JavaScript开发社区最知名的权威,是JSON.JSLint.JSMin和ADSafe之父,是<JavaScript:The Good Parts>(英文版.中文版)的作者.JavaScript的发明人Brendan Eich说他是"Yoda of lambda programming and JavaScript(lambda编程和JavaScript的精神领袖)".他同时也服务于ECMA的Ja

  • JavaScript 读取图片实例代码

    Untitled Page JavaScript读取图片测试例子 '); var a = 0; var b = 1; Loading(a,b); } //显示加载失败信息 function Gif_Err() { alert("载入失败!") } //显示加载成功信息 function Gif_End() { alert("载入完成!") } //加载图片,并显示 function Loading(a,b) { //当数组元素为空时,切换数组的一维 if (!Gif

  • JavaScript数据类型和变量_动力节点Java学院整理

    数据类型 计算机顾名思义就是可以做数学计算的机器,因此,计算机程序理所当然地可以处理各种数值.但是,计算机能处理的远不止数值,还可以处理文本.图形.音频.视频.网页等各种各样的数据,不同的数据,需要定义不同的数据类型.在JavaScript中定义了以下几种数据类型: Number JavaScript不区分整数和浮点数,统一用Number表示,以下都是合法的Number类型: 123; // 整数123 0.456; // 浮点数0.456 1.2345e3; // 科学计数法表示1.2345x

  • 关于javascript中dataset的问题小结

    DataSet是ADO.NET的中心概念.可以把DataSet当成内存中的数据库,DataSet是不依赖于数据库的独立数据集合.所谓独立,就是说,即使断开数据链路,或者关闭数据库,DataSet依然是可用的,DataSet在内部是用XML来描述数据的,由于XML是一种与平台无关.与语言无关的数据描述语言,而且可以描述复杂关系的数据,比如父子关系的数据,所以DataSet实际上可以容纳具有复杂关系的数据,而且不再依赖于数据库链路. 一.关于dataset 1.html5自定义属性及基础 html5

  • javascript函数中执行c#函数的方法

    1如何在JavaScript访问C#函数? 2.如何在JavaScript访问C#变量? 3.如何在C#中访问JavaScript的已有变量? 4.如何在C#中访问JavaScript函数? 问题1答案如下: javaScript函数中执行C#代码中的函数: 方法一:1.首先建立一个按钮,在后台将调用或处理的内容写入button_click中; 2.在前台写一个js函数,内容为document.getElementById("btn1").click(); 3.在前台或后台调用js函数

  • JavaScript 密码强度判断代码

    复制代码 代码如下: <script type="text/javascript"> //CharMode函数 //测试某个字符是属于哪一类. function CharMode(iN){ if (iN>=48 && iN <=57) //数字 return 1; if (iN>=65 && iN <=90) //大写字母 return 2; if (iN>=97 && iN <=122)

随机推荐