詳解JavaScript函數(shù)callee、call、apply的區(qū)別
arguments.callee
關于callee的解釋:callee 是 arguments 對象的一個屬性。可以用于引用該函數(shù)的函數(shù)體內(nèi)當前正在執(zhí)行的函數(shù)。這在函數(shù)的名稱是未知時很有用,例如在沒有名稱的函數(shù)表達式 (也稱為“匿名函數(shù)”)內(nèi)。
遞歸調(diào)用實現(xiàn)一個階乘函數(shù):
function sum(num){ if(num <= 1){ return 1; }else{ console.log(num, arguments.callee(num-1)); return num * arguments.callee(num-1); } } console.log(sum(3));
apply使用情況
function box(num1,num2){ return num1+num2; } function sum(num1,num2){ //this 表示全局作用域,瀏覽器環(huán)境下window,node環(huán)境global,[]表示傳遞的參數(shù) return box.apply(this,[num1,num2]); //或者下面寫法arguments可以當數(shù)組傳遞 //return box.apply(this,arguments); } console.log(sum(10,10)); //輸出結果: 20
call的使用示例
function box(num1,num2){ return num1+num2; } function sum2(num1,num2){ return box.call(this,num1,num2); } console.log(sum(10,10)); //輸出結果: 20
總結call、apply兩種情況使用的區(qū)別: call傳遞參數(shù)是按照數(shù)組傳遞,apply是一個一個傳遞
以上所述是小編給大家介紹的JavaScript函數(shù)callee、call、apply的區(qū)別詳解整合,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
- JavaScript函數(shù)的4種調(diào)用方法詳解
- JavaScript函數(shù)的調(diào)用以及參數(shù)傳遞
- 深入理解JavaScript函數(shù)參數(shù)(推薦)
- 超鏈接怎么正確調(diào)用javascript函數(shù)
- 改變javascript函數(shù)內(nèi)部this指針指向的三種方法
- 從JQuery源碼分析JavaScript函數(shù)的apply方法與call方法
- 用apply讓javascript函數(shù)僅執(zhí)行一次的代碼
- JavaScript函數(shù)之call、apply以及bind方法案例詳解
- JavaScript函數(shù)apply()和call()用法與異同分析
- 玩轉JavaScript函數(shù):apply/call/bind技巧
相關文章
解決 firefox 不支持 document.all的方法
解決 firefox 不支持 document.all的方法...2007-03-03關于不同頁面之間實現(xiàn)參數(shù)傳遞的幾種方式討論
下面小編就為大家?guī)硪黄P于不同頁面之間實現(xiàn)參數(shù)傳遞的幾種方式討論。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-02-02