第一道:
function foo(){foo.abc = function(){alert('Alibaba')}this.abc = function(){alert('Alimama')}abc = function(){alert('Alipay')};var abc = function(){alert('Taobao')}}foo.prototype.abc = function(){alert('Alisoft');}foo.abc = function(){alert('Yahoo');}var obj = new foo();obj.abc();foo.abc();abc();
我們就直接針對這輸出按順序進行分析,
執行順序
1.foo.prototype.abc = function(){alert('Alisoft');}
//這樣之後,我們就可以用obj.abc();不懂prototype原型的,可以看這個prototype原型繼承
2.foo.abc = function(){alert('Yahoo');}
//alert yahoo
3.var obj = new foo();
//建立一個foo的執行個體obj,同時,執行了foo函數,也就是obj.abc() = function(){alert('Alimama')}
4.foo.abc = function(){alert('Alibaba')}
//foo.abc是foo類的靜態方法,在執行個體化foo後執行了程式碼片段foo.abc = function()
//覆蓋了原來的foo.abc = function(){alert('Yahoo');},所以foo.abc()輸出alibaba
5.this.abc = function(){alert('Alimama')}
//這句話把function(){alert('Alimama')賦給了obj.abc,所以obj.abc輸出alimama
6.abc = function(){alert('Alipay')}; var abc = function(){alert('Taobao')};
//這兩句一起分析,如果沒有下一句,那麼abc是個全域變數,abc輸出alipay
//但是因為下一句var abc之後,abc的範圍被限制在foo類裡,所以外部的abc()會顯示未定義.
alimama alibaba undefined
第二道:
f = function() { return true; };
g = function() { return false; };
(function() {
if (g() && [] == ![]) {
f = function f() { return false; };
function g() { return true; }
}
})();
alert(f()); // true or false ?
true
第三道:
var o = {
m: function() {
return this.length;
},
length: 1
};
var m = o.m;
alert(m()); // 請問輸出什麼? 並解釋為什麼。
0