javascript遞歸函數(shù)問題求大神看看
問題描述
大神晚上好,請幫我看看我的函數(shù)為什么不能執(zhí)行呢?情況說明:由于p中的table是通過ajax加載過來的,函數(shù)的目的是判斷有沒有這table,如果有則讓其背景變紅,沒有的話,就1秒后再執(zhí)行以下這個函數(shù),但是現(xiàn)在當table已經(jīng)加載顯示后,find()函數(shù)并沒有讓table變紅(報錯:Uncaught RangeError: Maximum call stack size exceeded)先謝謝大神們了!
問題解答
回答1:因為你用p.getElementsByTagName(’table’)[0]這個取到的是一個DOM對象,由于DOM對象沒有.length屬性,所以target.length其實是未定義的。而undefined > 0的值一直是false,所以你會無限次地調(diào)用else分支,所以也就會添加無數(shù)次的find(p)綁定。所以瀏覽器提示find調(diào)用次數(shù)超出最大限制。
正確的做法是讓target為p.getElementsByTagName('table'),這才是一個數(shù)組,才有.length的值。
Update代碼:方案1:(判斷取到所有table的數(shù)組長度,并取第一個操作)
function find(p) { var target = p.getElementsByTagName('table'); if (target.length > 0) {target[0].style.background = ’red’; } else {setTimeout(function() { find(p);}, 1000) }};
方案2:(直接判斷table,并直接操作取到的table)
function find(p) { var target = p.getElementsByTagName('table')[0]; if (target) {target.style.background = ’red’; } else {setTimeout(function() { find(p);}, 1000) }};回答2:
target.length target 是 table, table.length 是什么?
參考一下
function find(p) { var interval = setInterval(function () { var target = p.getElementsByTagName('table')[0] if (target) { clearInterval(interval) target.style.background = ’red’ } }, 1000)}
相關(guān)文章:
1. javascript - 在ie下為什么會出現(xiàn)這種情況呢 《 無法獲取未定義或 null 引用的屬性“l(fā)ength”》 ?請大神指教。2. css右浮動字的順序顛倒了3. javascript - 我是做web前端的,公司最近有一個項目關(guān)于數(shù)據(jù)統(tǒng)計的!4. html5和Flash對抗是什么情況?5. javascript - 只是想用node建立一個簡單的服務器6. MySQL主鍵沖突時的更新操作和替換操作在功能上有什么差別(如圖)7. javascript - vue過渡效果 css過渡 類名的先后順序8. javascript - vuejs+elementui 購物車價格計算,點擊加減號修改數(shù)量總價都不會改變,但是計算執(zhí)行了9. 數(shù)據(jù)庫 - Mysql的存儲過程真的是個坑!求助下面的存儲過程哪里錯啦,實在是找不到哪里的問題了。10. javascript - 如何使用loadash對[object,object,object]形式的數(shù)組進行比較
