javascript递归函数问题求大神看看

发布于 2022-09-05 02:57:06 字数 620 浏览 16 评论 0

大神晚上好,请帮我看看我的函数为什么不能执行呢?
情况说明:由于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 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(2

佼人 2022-09-12 02:57:06

因为你用div.getElementsByTagName('table')[0]这个取到的是一个DOM对象,由于DOM对象没有.length属性,所以target.length其实是未定义的。而undefined > 0的值一直是false,所以你会无限次地调用else分支,所以也就会添加无数次的find(div)绑定。所以浏览器提示find调用次数超出最大限制。

正确的做法是让targetdiv.getElementsByTagName("table"),这才是一个数组,才有.length的值。

Update

代码:
方案1:(判断取到所有table的数组长度,并取第一个操作)

function find(div) {
    var target = div.getElementsByTagName("table");
    if (target.length > 0) {
        target[0].style.background = 'red';
    } else {
        setTimeout(function() {
            find(div);
        }, 1000)
    }
};

方案2:(直接判断table,并直接操作取到的table)

function find(div) {
    var target = div.getElementsByTagName("table")[0];
    if (target) {
        target.style.background = 'red';
    } else {
        setTimeout(function() {
            find(div);
        }, 1000)
    }
};
从来不烧饼 2022-09-12 02:57:06

target.length target 是 table, table.length 是什么?

参考一下

function find(div) {
  var interval = setInterval(function () {
    var target = div.getElementsByTagName("table")[0]
    if (target) {
      clearInterval(interval)
      target.style.background = 'red'
    }
  }, 1000)
}
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文