众所周知,DOMNodeInserted 会使动态页面变慢,MDN 甚至建议不要完全使用它,但没有提供任何替代方案。
我对插入的元素不感兴趣,我只需要知道某个脚本何时修改了 DOM。是否有更好的替代突变事件侦听器(可能在 nsiTimer 中使用 getElementsByTagName)?
众所周知,DOMNodeInserted 会使动态页面变慢,MDN 甚至建议不要完全使用它,但没有提供任何替代方案。
我对插入的元素不感兴趣,我只需要知道某个脚本何时修改了 DOM。是否有更好的替代突变事件侦听器(可能在 nsiTimer 中使用 getElementsByTagName)?
如果您正在创建针对最近的手机和更新版本的浏览器(Firefox 5+、Chrome 4+、Safari 4+、iOS Safari 3+、Android 2.1+)的网络应用程序,您可以使用以下代码创建一个很棒的用于插入 dom 节点的事件,它甚至在最初是页面静态标记的一部分的节点上运行!
这是完整帖子的链接和示例:http : //www.backalleycoder.com/2012/04/25/i-want-a-damnodeinserted/
关于 Mutation Observers 的注意事项:虽然最近浏览器中较新的 Mutation Observers 功能非常适合监控对 DOM 的简单插入和更改,但请了解此方法可用于执行更多操作,因为它允许您监控任何与您匹配的 CSS 规则可以的东西。这对于许多用例来说都非常强大,所以我将它封装在一个库中:https : //github.com/csuwildcat/SelectorListener
如果您想针对各种浏览器,您需要向 CSS 和 animationstart 事件名称添加适当的前缀。您可以在上面链接的帖子中阅读更多相关信息。
CSS :
@keyframes nodeInserted {
from {
outline-color: #fff;
}
to {
outline-color: #000;
}
}
div.some-control {
animation-duration: 0.01s;
animation-name: nodeInserted;
}
JavaScript :
document.addEventListener('animationstart', function(event){
if (event.animationName == 'nodeInserted'){
// Do something here
}
}, true);
这使得 Mutation Observers 几乎不可能做到的事情成为可能
CSS :
@keyframes adjacentFocusSequence {
from {
outline-color: #fff;
}
to {
outline-color: #000;
}
}
.one + .two + .three:focus {
animation-duration: 0.01s;
animation-name: adjacentFocusSequence;
}
JavaScript :
document.addEventListener('animationstart', function(event){
if (event.animationName == 'adjacentFocusSequence'){
// Do something here when '.one + .two + .three' are
// adjacent siblings AND node '.three' is focused
}
}, true);
@naugtur 简要提到的一种新选择是MutationObserver。如果您正在开发的浏览器支持它(例如,如果您正在开发浏览器扩展),它被设计为已弃用的突变事件的替代品。
与 csuwldcat 描述的相同的技术已被制作成一个易于使用的 jQuery 插件(如果这是你的东西):https : //github.com/liamdanger/jQuery.DOMNodeAppear
这是张贴在这里,因为这个问题是我在 DOMNodeInserted 与 IE9 失败的情况下寻求帮助的地方,但请注意,此解决方案专门用于在使用 End Request 函数的 ASP.NET 上下文中使用 jQuery 的情况。您的里程可能会有所不同,等等......
基本上,我们将完全丢弃 DOMNodeInserted 并使用 End Request 加载我们的事件处理程序:
老的:
$(document).ready(function() {
$(document).bind('DOMNodeInserted', function(event){
My jQuery event handler...
});
});
====================================
新的:
function Ajax_EndRequest {
function2();
}
function2 (a,b){
My jQuery event handler...
}
$(document).ready(function(){
add_endRequest(Ajax_EndRequest); //this is what actually invokes the function upon request end.
My jQuery event handler...//REMOVED -- don't need this now
});
如果您只想在 DOM 更改时触发事件,请执行以下操作:
var nodes=document.getElementsByTagName('*')||document.all;
function domchange(){
alert('Hello');
}
window.setInterval(function(){
var newnodes=document.getElementsByTagName('*')||document.all;
if(newnodes!=nodes){
nodes=newnodes;
domchange();
}
},1);