您好,登錄后才能下訂單哦!
小編給大家分享一下JavaScript函數(shù)callee、call、apply的區(qū)別有哪些,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
arguments.callee
關(guān)于callee的解釋:callee 是 arguments 對象的一個屬性??梢杂糜谝迷摵瘮?shù)的函數(shù)體內(nèi)當(dāng)前正在執(zhí)行的函數(shù)。這在函數(shù)的名稱是未知時很有用,例如在沒有名稱的函數(shù)表達(dá)式 (也稱為“匿名函數(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可以當(dāng)數(shù)組傳遞 //return box.apply(this,arguments); } console.log(sum(10,10)); //輸出結(jié)果: 20
call的使用示例
function box(num1,num2){ return num1+num2; } function sum2(num1,num2){ return box.call(this,num1,num2); } console.log(sum(10,10)); //輸出結(jié)果: 20
總結(jié)call、apply兩種情況使用的區(qū)別: call傳遞參數(shù)是按照數(shù)組傳遞,apply是一個一個傳遞
以上是“JavaScript函數(shù)callee、call、apply的區(qū)別有哪些”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。