当前位置: 首页 > 面试题库 >

JavaScript检测DOM中的更改

宗政洋
2023-03-14
问题内容

当某些div或输入添加到html时,我想执行一个函数。这可能吗?

例如,添加文本输入,然后应调用该函数。


问题答案:

MutationObserver现代浏览器支持新功能:

Chrome 18以上版本,Firefox 14以上版本,IE 11以上版本,Safari 6以上版本

如果您需要支持较旧的方法,则可以尝试使用其他方法,例如下面这个5(!)年的答案中提到的方法。有龙。请享用 :)

有人在更改文档吗?因为如果您完全控制更改,则只需要创建自己的domChangedAPI(带有函数或自定义事件),然后在修改所有内容时触发/调用它即可。

在DOM Level-2的具有突变的事件类型,但IE浏览器的旧版本不支持它。请注意,DOM3事件规范中不赞成使用突变事件,并且会降低性能。

您可以尝试 onpropertychange 在IE中模拟突变事件(如果没有可用的方法,可以使用暴力破解方法)。

对于 完整的 domChange,间隔可能是一个过大的杀伤力。想象一下,您需要存储整个文档的当前状态,并检查每个元素的每个属性是否相同。

也许如果您只对元素及其顺序感兴趣(如您在问题中所提到的),那么getElementsByTagName("*")可以使用a。如果您添加元素,删除元素,替换元素或更改文档的结构,则会自动触发。

我写了一个概念证明:

(function (window) {
    var last = +new Date();
    var delay = 100; // default delay

    // Manage event queue
    var stack = [];

    function callback() {
        var now = +new Date();
        if (now - last > delay) {
            for (var i = 0; i < stack.length; i++) {
                stack[i]();
            }
            last = now;
        }
    }

    // Public interface
    var onDomChange = function (fn, newdelay) {
        if (newdelay) delay = newdelay;
        stack.push(fn);
    };

    // Naive approach for compatibility
    function naive() {

        var last = document.getElementsByTagName('*');
        var lastlen = last.length;
        var timer = setTimeout(function check() {

            // get current state of the document
            var current = document.getElementsByTagName('*');
            var len = current.length;

            // if the length is different
            // it's fairly obvious
            if (len != lastlen) {
                // just make sure the loop finishes early
                last = [];
            }

            // go check every element in order
            for (var i = 0; i < len; i++) {
                if (current[i] !== last[i]) {
                    callback();
                    last = current;
                    lastlen = len;
                    break;
                }
            }

            // over, and over, and over again
            setTimeout(check, delay);

        }, delay);
    }

    //
    //  Check for mutation events support
    //

    var support = {};

    var el = document.documentElement;
    var remain = 3;

    // callback for the tests
    function decide() {
        if (support.DOMNodeInserted) {
            window.addEventListener("DOMContentLoaded", function () {
                if (support.DOMSubtreeModified) { // for FF 3+, Chrome
                    el.addEventListener('DOMSubtreeModified', callback, false);
                } else { // for FF 2, Safari, Opera 9.6+
                    el.addEventListener('DOMNodeInserted', callback, false);
                    el.addEventListener('DOMNodeRemoved', callback, false);
                }
            }, false);
        } else if (document.onpropertychange) { // for IE 5.5+
            document.onpropertychange = callback;
        } else { // fallback
            naive();
        }
    }

    // checks a particular event
    function test(event) {
        el.addEventListener(event, function fn() {
            support[event] = true;
            el.removeEventListener(event, fn, false);
            if (--remain === 0) decide();
        }, false);
    }

    // attach test events
    if (window.addEventListener) {
        test('DOMSubtreeModified');
        test('DOMNodeInserted');
        test('DOMNodeRemoved');
    } else {
        decide();
    }

    // do the dummy test
    var dummy = document.createElement("div");
    el.appendChild(dummy);
    el.removeChild(dummy);

    // expose
    window.onDomChange = onDomChange;
})(window);

用法:

onDomChange(function(){ 
    alert("The Times They Are a-Changin'");
});

适用于IE 5.5 +,FF 2 +,Chrome,Safari 3+和Opera 9.6+



 类似资料:
  • 问题内容: 我需要一种有效的机制来检测DOM的更改。最好是跨浏览器,但如果有任何 非 跨浏览器的有效手段,我可以使用故障保护跨浏览器方法来实现。 特别是,我需要检测可能会影响页面上文本的更改,因此需要进行任何新的,删除或修改的元素或对内部文本(innerHTML)的更改。 我无法控制所做的更改(它们可能是由于第三方JavaScript包含,等等),因此无法从这个角度进行处理-我需要以某种方式“监视

  • 在JavaFX的中,我正在努力检测URL的变化。 我在一个类中有这个方法: 我试图将其用于一个名为loginbrowser的对象,比如: 你知道我做错了什么吗?

  • 问题内容: 如何使用JavaScript确定确切的浏览器和版本? 问题答案: 顾名思义,这将告诉您浏览器提供的名称和版本号。 当您在多个浏览器上测试新代码时,它对于对测试结果和错误结果进行排序非常方便。

  • 变化检测器的目标是知道从上一次变化检测过程运行以来,组件的模板中使用的哪些模型属性已经改变。 为了知道,Angular创建了一个适当的变化检测器类的实例和一个链接到它应该检查的组件。 在我们的示例中,因为我们只有一个和MovieComponent的实例,我们将只有一个MainComponent_ChangeDetector和MovieComponent_ChangeDetector的实例。 下面的

  • 我得到了一个组件,它只是一个/-计数器。我可以从这个组件中获取我需要的值的引用,如下所示: 显示来自组件的正确值,但我不知道如何在父组件中观察此值的变化。对我来说,修改此子组件的代码非常困难,在这种情况下,我可能会使用来通知父组件更改。 我如何在我的父组件中为这个的注册一个等待器?

  • 问题内容: 我对用于检测某个HTML元素是否添加到HTML页面中的任何位置感兴趣。例如,我要说的是,我想检测是否在DOM中的任何位置添加了。 到目前为止,我所看到的所有示例仅检测是否将节点添加到特定容器中。例如: 一些HTML 定义 因此,在此示例中,设置用于监视非常特定的容器(),以查看是否将任何附加到其上。 如果我不想 那么具体 ,是否在整个HTML正文中关注,是否会出现这样的问题: 我知道它