javascript递归函数问题求大神看看
大神晚上好,请帮我看看我的函数为什么不能执行呢?
情况说明:由于div中的table是通过ajax加载过来的,函数的目的是判断有没有这table,如果有则让其背景变红,没有的话,就1秒后再执行以下这个函数,但是现在当table已经加载显示后,find()函数并没有让table变红(报错:Uncaught RangeError: Maximum call stack size exceeded)
先谢谢大神们了!?
函数如下:
function find(div) {
var target = div.getElementsByTagName("table")[0];
if (target.length > 0) {
target.style.background = 'red';
} else {
setTimeout(function() {
find(div); //arguments.callee(div)也不行
}, 1000)
}
};
使用:
var div = document.getElementById('div');
find(div);
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论
评论(2)
因为你用
div.getElementsByTagName('table')[0]
这个取到的是一个DOM对象,由于DOM对象没有.length
属性,所以target.length
其实是未定义的。而undefined > 0
的值一直是false
,所以你会无限次地调用else
分支,所以也就会添加无数次的find(div)
绑定。所以浏览器提示find
调用次数超出最大限制。正确的做法是让
target
为div.getElementsByTagName("table")
,这才是一个数组,才有.length
的值。Update
代码:
方案1:(判断取到所有table的数组长度,并取第一个操作)
方案2:(直接判断table,并直接操作取到的table)
target.length
target 是 table, table.length 是什么?参考一下