javascript递归函数问题求大神看看
问题描述
大神晚上好,请帮我看看我的函数为什么不能执行呢?情况说明:由于p中的table是通过ajax加载过来的,函数的目的是判断有没有这table,如果有则让其背景变红,没有的话,就1秒后再执行以下这个函数,但是现在当table已经加载显示后,find()函数并没有让table变红(报错:Uncaught RangeError: Maximum call stack size exceeded)先谢谢大神们了!
问题解答
回答1:因为你用p.getElementsByTagName(’table’)[0]这个取到的是一个DOM对象,由于DOM对象没有.length属性,所以target.length其实是未定义的。而undefined > 0的值一直是false,所以你会无限次地调用else分支,所以也就会添加无数次的find(p)绑定。所以浏览器提示find调用次数超出最大限制。
正确的做法是让target为p.getElementsByTagName('table'),这才是一个数组,才有.length的值。
Update代码:方案1:(判断取到所有table的数组长度,并取第一个操作)
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)}
相关文章:
1. javascript - easyui textbox绑定onchange事件不能获取最新的文本框的值2. javascript - 一个字符串转换成数字,例子就是a="2,322.222",b=’1,211.21’,如何在angualr中执行相减3. 利用百度地图API定位及附件商家信息服务4. javascript - 如何在windows下搭建react开发环境上,实现网站的react版本5. javascript - 读取页面源码,页面中所有的换行都被当成<br/>读取出来 了,,求解应该怎么让它被正确的解析6. windows - python pymysql 返回值是int类型7. mysql sql where id in(25,12,87) 结果集如何用按照 25 12 87排序?8. PHP类属性声明?9. html5 - 移动端通过拖拽实现两个元素的位置互换10. javascript - js 修改表格元素的,可以用DOM操作实现吗?