翻到了这篇解释Javascript quiz的文章quiz-legend,反正没事儿,就想搬过来供大家学习、理解、背诵、批判。 问题一 (function(){ return typeof arguments;//'object'})(); arguments是一个Array-like对象,对应的就是传入函数的参数列表。你可以在任何函数中直接使用该变量。 由此我们推断出,typeof arguments是object 问题二 var f = function g(){ return 23; };typeof g();//报错 这是一个名字是g的function expression,然后又被赋值给了变量f。 问题三 (function(x){ delete x; return x;//1})(1); delete操作符可以从对象中删除属性,正确用法如下: 你最好也知道,delete是不会直接释放内存的,她只是间接的中断对象引用 问题四 问题五 (function f(f){ return typeof f();//'number'})(function(){ return 1; }); 直接上注释解释: (function f(f){ //这里的f是传入的参数function(){ return 1; } //执行的结果自然是1 return typeof f(); //所以根据问题一的表格我们知道,typeof 1结果是'number'})(function(){ return 1; }); 问题六 var foo = { bar: function() { return this.baz; }, baz: 1};(function(){ return typeof arguments[0]();//'undefined'})(foo.bar); 这里你可能会误以为最终结果是number。向函数中传递参数可以看作是一种赋值,所以arguments[0]得到是是真正的bar函数的值,而不是foo.bar这个引用,那么自然this也就不会指向foo,而是window了。 问题七 var foo = { bar: function(){ return this.baz; }, baz: 1}typeof (f = foo.bar)();//'undefined' 这和上一题是一样的问题,(f = foo.bar)返回的就是bar的值,而不是其引用,那么this也就指的不是foo了。 问题八 var f = (function f(){ return '1'; }, function g(){ return 2; })();typeof f;//'number' 逗号操作符 对它的每个操作对象求值(从左至右),然后返回最后一个操作对象的值 所以(function f(){ return '1'; }, function g(){ return 2; })的返回值就是函数g,然后执行她,那么结果是2;最后再typeof 2,根据问题一的表格,结果自然是number 问题九 var x = 1;if (function f(){}) { x += typeof f;}x;//'1undefined' 这个问题的关键点,我们在问题二中谈到过,function expression中的函数名f是不能在函数体外部访问的 问题十 var x = [typeof x, typeof y][1];typeof typeof x;//'string' 1.因为没有声明过变量y,所以typeof y返回'undefined' 2.将typeof y的结果赋值给x,也就是说x现在是'undefined' 问题十一 (function(foo){ return typeof foo.bar;//'undefined'})({ foo: { bar: 1 } }); 这是个纯粹的视觉诡计,上注释 (function(foo){ //这里的foo,是{ foo: { bar: 1 } },并没有bar属性哦。 //bar属性是在foo.foo下面 //所以这里结果是'undefined' return typeof foo.bar;})({ foo: { bar: 1 } }); 问题十二 (function f(){ function f(){ return 1; } return f();//2 function f(){ return 2; }})(); 通过function declaration声明的函数甚至可以在声明之前使用,这种特性我们称之为hoisting。于是上述代码其实是这样被运行环境解释的: (function f(){ function f(){ return 1; } function f(){ return 2; } return f();})(); 问题十三 function f(){ return f; }new f() instanceof f;//false 当代码new f()执行时,下面事情将会发生: ps:一般情况下构造函数不返回任何值,不过用户如果想覆盖这个返回值,可以自己选择返回一个普通对象来覆盖。当然,返回数组也会覆盖,因为数组也是对象。 于是,我们这里的new f()返回的仍然是函数f本身,而并非他的实例 问题十四 OK,现在我们来看,由于function(x, undefined){}是一个匿名函数表达式,是函数,就会有length属性,指的就是函数的参数个数。所以最终结果就是2了 写在最后 有人觉得这些题坑爹,也有人觉得开阔了眼界,见仁见智吧。但有一件事是真的,无论你?理论基础,也铁定走不远 - 你永远不会见到哪个熟练的技术工人突然成了火箭专家。 看文档、读标准、结合实践,才是同志们的决胜之道。 以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。 |
|