javascript – 为什么我的自定义jQuery`change`事件被触发两次?

前端之家收集整理的这篇文章主要介绍了javascript – 为什么我的自定义jQuery`change`事件被触发两次?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

我是一个jQuery兼容的复合HTML输入trying to make.

this example中,当任一选择更改时,将调用警报两次.为什么?

给定一个简单的容器节点:

这是一个完全有效的演示:

function el (type) {
    return document .createElement (type);
}

function opt (sel,value) {
    let node = el ('option');
    node .value = value;
    node .appendChild (document .createTextNode (value));
    sel .appendChild (node);
}

let x = document .getElementById ('x');
let a = el ('select');
let b = el ('select');

x .appendChild (a);
x .appendChild (b);

opt (a,'a_1');
opt (a,'a_2');
opt (b,'b_1');
opt (b,'b_2');

$(a) .change (function () {$(x) .trigger ('change');});
$(b) .change (function () {$(x) .trigger ('change');});

$(x) .change (function () {alert ('changed');});
最佳答案
因为当您在下拉列表中更改值时,它会更改父元素的drom结构.它意味着你正在改变A和B的值,它的A和B的专利是X,所以它会自动改变,所以你必须停止事件传播

你必须删除下面的代码

$(a) .change (function () {$(x) .trigger ('change');});
$(b) .change (function () {$(x) .trigger ('change');});

或者你必须使用preventDefault();

$(a) .change (function (e) {e.preventDefault(); $(x) .trigger ('change'); return false; });
$(b) .change (function (e) {e.preventDefault(); $(x) .trigger ('change'); return false; });

猜你在找的jQuery相关文章