DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> 關於JavaScript >> Function.prototype.call.apply結合用法分析示例
Function.prototype.call.apply結合用法分析示例
編輯:關於JavaScript     
昨天在網上看到一個很有意思的js面試題,就跟同事討論了下,發現剛開始很繞最後豁然開朗,明白過來之後發現還是挺簡單的,跟大家分享下!
題目如下:var a = Function.prototype.call.apply(function(a){return a;}, [0,4,3]);alert(a);

分析步驟如下:
1、將Function.prototype.call當成整體,call方法是由浏覽器實現的本地方法,是函數類型的內部方法
var a = (Function.prototype.call).apply(function(a){return a;}, [0,4,3]);

2、fun.apply(obj,args)等價於obj.fun(args),這一步是重點,必須理解!
(function(a){return a;}).apply(0,[4,3])
(function(a){return a;}).call(0,4,3)

3、 到這步結果就很明顯了,a就是4,alert的結果就是4

這個題目迷惑的點就在於Function.prototype.call,理解好了,就清晰明了了!
XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved