gpt4 book ai didi

javascript - 为什么这段代码中需要 setTimeout

转载 作者:行者123 更新时间:2023-12-03 11:02:09 25 4
gpt4 key购买 nike

$(document).on('click', '#JS_btn1', function(e) {
var self = $(this);
setTimeout(function(){
self.parent('div').html('<a href="javascript:void(0);" class="btn_ok" id="JS_btn2">OK</a>');
});
})

代码显示,在完成监听器事件之前,#JS_btn1 被#JS_btn2 替换。现在的问题是,为什么在IE7/8中需要setTimeout来防止错误?

最佳答案

最有可能的是,IE 7/8 持有对您要替换的 DOM 节点的引用,然后尝试检索节点名称。由于该节点已在您的函数中以及 DOM 中删除,因此 IE 会抛出错误。调用 setTimeout() 允许调用者在替换节点之前释放该节点。

关于javascript - 为什么这段代码中需要 setTimeout,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28037402/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com