您好,登錄后才能下訂單哦!
這篇文章主要講解了“js遞歸函數調用本函數的方式是什么”,文中的講解內容簡單清晰,易于學習與理解,下面請大家跟著小編的思路慢慢深入,一起來研究和學習“js遞歸函數調用本函數的方式是什么”吧!
通常javascript代碼可以與HTML標簽一起直接放在前端頁面中,但如果JS代碼多的話一方面不利于維護,另一方面也對搜索引擎不友好,因為頁面因此而變得臃腫,因此需要知道js函數的遞歸調用方法。
js函數的遞歸調用方法
1.通過函數自身名字遞歸調用
復制代碼
functionsum(num){
if(num<=1){
return1;
}else{
returnnum+sum(num-1);
}
}
console.log(sum(5));//15
復制代碼
這種通過函數名字調用自身的方式存在一個問題:函數的名字是一個指向函數對象的指針,如果我們把函數的名字與函數對象本身的指向關系斷開,這種方式運行時將出現錯誤。
2.通過arguments.callee調用函數自身
復制代碼
functionsum(num){
if(num<=1){
return1;
}else{
returnnum+arguments.callee(num-1);
}
}
console.log(sum(5));//15
varsumAnother=sum;
console.log(sumAnother(5));//15
sum=null;
console.log(sumAnother(5));//15
復制代碼
這種方式很好的解決了函數名指向變更時導致遞歸調用時找不到自身的問題。但是這種方式也不是很完美,因為在嚴格模式下是禁止使用arguments.callee的。
js遞歸函數怎么自己調用自己
<divid="_div">點擊</div>
<scripttype="text/javascript"src="js/jquery-1.11.1.min.js"></script>
<scripttype="text/javascript">
functionsetNum(i){
if(i>2){
i--;
returnsetNum(i);
}else{
returni;
}
}
$("#_div").click(function(){
varm=setNum(6);
$("#_div").html("點擊"+m);
})
</script>
感謝各位的閱讀,以上就是“js遞歸函數調用本函數的方式是什么”的內容了,經過本文的學習后,相信大家對js遞歸函數調用本函數的方式是什么這一問題有了更深刻的體會,具體使用情況還需要大家實踐驗證。這里是億速云,小編將為大家推送更多相關知識點的文章,歡迎關注!
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。