- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个简单的 chrome 扩展,它与页面的 DOM 一起使用(它寻找看起来像登录表单的“东西”)。问题是,许多页面都有“动态”登录表单 - 它的代码在需要时加载。这就是为什么 body 的 onload 事件是不够的。
因此,我创建了突变观察器,并在每次 DOM 更改时执行我的程序(将来会有一些限制 - 其中许多更改不会影响我的目的)
由于某些时间间隔,我必须在更新的 DOM 上实现程序的延迟执行(时间 500 仅用于测试目的)
var target = document.body;
var timer;
var observer = new MutationObserver(function(mutations) {
mutations.forEach(function(mutation) {
var count = mutation.addedNodes.length;
if( count > 0) {
timer = setTimeout(function (){
console.log("executed");
my_procedure();
}, 500);
}
});
});
var config = { attributes: true, childList: true, characterData: true };
observer.observe(target, config);
问题是,setTimeout 不断触发到无穷大,这使得页面在一段时间后变得非常懒惰。在 Chrome JS 控制台中,“已执行”消息的数量仍在增加。
我知道 clearTimeout(timer)
,但我无法正确使用它 - 因此 my_procedure
对于每个 DOM 更改仅执行一次。
编辑:my_procedure
实际上是第3方库函数,所以我不想(或可以)更改它 - 该函数启动整个表单分类逻辑。
感谢您的建议。
最佳答案
在 my_procedure() 中你可以使用
clearTimeout(timer);
放在第一行以避免多次出现
更新代码:
var target = document.body;
var timer;
var counter = 0;
var observer = new MutationObserver(function(mutations) {
mutations.forEach(function(mutation) {
var count = mutation.addedNodes.length;
clearTimeout(timer);
if( count > 0) {
if(counter == 0){
counter = 1;
timer = setTimeout(function (){
console.log("executed");
my_procedure();
}, 500);
}else {
clearTimeout(timer);
}
}
});
});
var config = { attributes: true, childList: true, characterData: true };
observer.observe(target, config);
关于javascript - setTimeout 不断触发,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24908354/
如果这不是一个错误,那就是另一个错误。如果不是那样的话,那就是别的东西了。我觉得我的项目已经改变了很多,现在只是试图解决代码签名问题,结果一切都搞砸了。我严格按照说明进行操作,但出现错误,例如当前的“
我不确定是否有一些我不知道的内置变量或规则,或者 make 是否有问题,或者我只是疯了。 对于我的一个项目,我有一个如下的 makefile: CC=g++ CFLAGS=-O3 `libpng-co
我有大约 10 个 div,它们必须不断翻转,每个 div 延迟 3 秒 这个 codrops 链接的最后一个效果是我正在寻找的,但无需单击 div http://tympanus.net/Devel
我如何使用 jQuery 持续运行 PHP 脚本并每秒获取响应,以及将鼠标上的少量数据发送到同一脚本? 我真的必须添加一些随机扩展才能让这么简单的计时器工作吗? 最佳答案 To iterate is
JBoss 4.x EJB 3.0 我见过如下代码(大大简化): @Stateless @TransactionAttribute(TransactionAttributeType.NOT_SUPPO
使用 PHPStorm,我试图忽略每次尝试进行 git 提交时 pop 的 workspace.xml。 我的 .gitignore 看起来像: /.idea/ .idea/workspace.xml
我是一名优秀的程序员,十分优秀!