首頁  >  文章  >  web前端  >  Function.prototype.call.apply結合用法分析範例_javascript技巧

Function.prototype.call.apply結合用法分析範例_javascript技巧

WBOY
WBOY原創
2016-05-16 17:30:271205瀏覽

昨天在網路上看到一個很有意思的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,理解好了,就清晰明了了!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn