Javascript 實現(xiàn)匿名遞歸的實例代碼
遞歸是一種常見的編程技巧,實名遞歸相信大家都不陌生,但如果想要實現(xiàn)匿名遞歸呢?比如想要返回一個匿名遞歸函數(shù),又或者是定義一個匿名遞歸函數(shù)并直接調(diào)用它,該怎樣去做呢?本文將來探討一下它的實現(xiàn)。
實名遞歸
我們還是先從實名遞歸說起吧,還是用那個最簡單的求階乘的例子:
function fact(n) {
if (n < 2) {
return n;
} else {
return n * fact(n - 1);
}
}
console.log(fact(5));
遞歸要求自己調(diào)用自己,如果函數(shù)有名字,這就太簡單不過了。
利用變量實現(xiàn)遞歸
函數(shù)還可以賦給一個變量,不過要實現(xiàn)遞歸,函數(shù)體里面還是要依賴這個變量名:
var f = function(n) {
if (n < 2) {
return n;
} else {
return n * f(n - 1);
}
}
console.log(f(5));
應(yīng)該說這種方式跟之前的其實沒有本質(zhì)的不同。
匿名遞歸
現(xiàn)在我們來探討匿名遞歸的實現(xiàn)。
初步設(shè)想
如果想要返回一個匿名遞歸函數(shù),又或者是定義一個匿名遞歸函數(shù)并直接調(diào)用它:
(function (n) {
if (n < 2) {
return n;
} else {
return n * ?(n - 1);
}
})(5);
如果沒有一個名字,代碼中那個問號我們就不知道要填寫什么,就沒法形成遞歸了,此時我們要怎么辦呢?這時就要請出 arguments 對象了。
arguments 對象
在 javascript 的函數(shù)中,arguments 對象代表了實際調(diào)用時的參數(shù)對象。在我們的遞歸函數(shù)中,實際上我們也可以完全不用去定義“形式參數(shù)” n:
function factNoParam() {
if (arguments[0] < 2) {
return arguments[0];
} else {
return arguments[0] * factNoParam(arguments[0] - 1);
}
}
console.log(factNoParam(5));
只要我們在調(diào)用時傳入了實際的參數(shù),就可以用 arguments[0] 取得實際傳入的這個參數(shù)的值。
如果有更多的參數(shù),還可以 arguments[1],arguments[2] 等來取得。
arguments.callee 屬性
arguments 可以用來獲取參數(shù),相信你可能已經(jīng)知道了,但 arguments 對象其實還有一個屬性,即所謂的 callee。arguments.callee 代表了這個函數(shù)本身。這是什么意思呢?其實我們完全可以把 fact 寫成這樣:
function fact(n) {
if (n < 2) {
return n;
} else {
return n * arguments.callee(n - 1);
}
}
console.log(fact(5));
那么它依然是遞歸的。因為 arguments.callee 實際就等于 fact。
那么,到了這里,有了這個屬性的幫助,要實現(xiàn)匿名遞歸就不難了,只要把 ? 改為 arguments.callee 即可:
(function (n) {
if (n < 2) {
return n;
} else {
return n * arguments.callee(n - 1);
}
})(5);
如果有需要,也可以把它作為匿名遞歸返回。
關(guān)于 javascript 實現(xiàn)匿名遞歸的介紹就到這里。希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- 利用java+mysql遞歸實現(xiàn)拼接樹形JSON列表的方法示例
- JS基于遞歸算法實現(xiàn)1,2,3,4,5,6,7,8,9倒序放入數(shù)組中的方法
- Vue.js 遞歸組件實現(xiàn)樹形菜單(實例分享)
- JS基于遞歸實現(xiàn)倒計時效果的方法
- AngularJS遞歸指令實現(xiàn)Tree View效果示例
- java、js中實現(xiàn)無限層級的樹形結(jié)構(gòu)方法(類似遞歸)
- javascript實現(xiàn)網(wǎng)頁子頁面遍歷回調(diào)的方法(涉及 window.frames、遞歸函數(shù)、函數(shù)上下文)
- 一個JavaScript遞歸實現(xiàn)反轉(zhuǎn)數(shù)組字符串的實例
- JavaScript中遞歸實現(xiàn)的方法及其區(qū)別
相關(guān)文章
JavaScript架構(gòu)前端不能沒有監(jiān)控系統(tǒng)原因
這篇文章主要為大家介紹了為什么前端不能沒有監(jiān)控系統(tǒng)的原因,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2022-06-06
javascript實現(xiàn)動態(tài)CSS換膚技術(shù)的腳本
javascript實現(xiàn)動態(tài)CSS換膚技術(shù)的腳本...2007-06-06
Three光源Target位置改變光照方向不變的問題解決方法
這篇文章主要為大家介紹了Three光源Target位置改變光照方向不變的問題及解決方法,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪2023-12-12
微信小程序如何調(diào)用json數(shù)據(jù)接口并解析
這篇文章主要介紹了微信小程序如何調(diào)用json數(shù)據(jù)接口并解析,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2019-06-06
關(guān)于原生js中bind函數(shù)的簡單實現(xiàn)
下面小編就為大家?guī)硪黄P(guān)于原生js中bind函數(shù)的簡單實現(xiàn)。小編覺得挺不錯的,現(xiàn)在就分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2016-08-08
JavaScript中的二進制數(shù)據(jù)處理方法詳解
Blob、ArrayBuffer和Buffer是JavaScript中用于表示和操作二進制數(shù)據(jù)的三種主要方式,本文將深入探討這些概念,以及它們?nèi)绾卧贘avaScript中使用,需要的可以參考一下2023-06-06
分享JavaScript監(jiān)聽全部Ajax請求事件的方法
最近在做一個小項目,引入了第三方j(luò)s文件,這個文件會調(diào)用XMLHttpRequest向服務(wù)器發(fā)送 Ajax請求,但是我有需要監(jiān)聽其Ajax請求的某些事件,以便額外地執(zhí)行其他腳本。于是稍微看了看監(jiān)聽 Ajax請求的事件方法,在這里分享給大家。有需要的朋友們可以參考借鑒。2016-08-08

