Javascript事件冒泡

时间:2011-05-11 23:10:13

标签: javascript event-bubbling

我有这个设置

<div onclick="SomeEvent">
    <input type=checkbox value=1>1
    <input type=checkbox value=2>2
    <input type=checkbox value=3>3
</div>

当用户点击复选框时我不希望SomeEvent被触发的问题。

在某些情况下,我确实有行
“event.stopPropagation();”
但这似乎什么都不做。

2 个答案:

答案 0 :(得分:6)

bubbling 模型中,事件传播是从内部元素到外部元素。

这意味着 event.stopPropagation(); 应该在输入'事件而不是div中。

<div onclick="SomeEvent">
  <input type=checkbox value=1 onclick="stopPropagation()">1
  <input type=checkbox value=2 onclick="stopPropagation()>2
  <input type=checkbox value=3 onclick="stopPropagation()>3
</div>

现在是Javascript代码:

function stopPropagation() {
  //... do something.
  //stop propagation:
  if (!e) var e = window.event;
  e.cancelBubble = true; //IE
  if (e.stopPropagation) e.stopPropagation(); //other browsers
}

更多信息:http://www.quirksmode.org/js/events_order.html

编辑:上面是一个快速展示冒泡模型如何工作的方法,但是使用JQuery解决这个问题的更好答案是:

<div id="mydiv">
  <input type="checkbox" value="1" /> 1
  <input type="checkbox" value="2" /> 2
  <input type="checkbox" value="3" /> 3
</div>

现在是Javascript代码:

$('#mydiv').click(function(e) {
  //do something
});

$('#mydiv input').click(function(e) {
  //stop propagation:
  if (!e) var e = window.event;
  e.cancelBubble = true; //IE
  if (e.stopPropagation) e.stopPropagation(); //other browsers
});

答案 1 :(得分:5)

将内联更改为:

onclick="SomeEvent(this, event)"

然后在SomeEvent中,执行此操作:

function SomeEvent( el, event ) {
    var target = event.srcElement || event.target;

    if( el === target ) {
        // run your code
    }
}

这只会在您单击div元素本身而不是后代时触发代码。

如果有其他后代应该触发处理程序,那么执行以下操作:

function SomeEvent( el, event ) {
    var target = event.srcElement || event.target;

    if( target.nodeName.toLowerCase() !== 'input' || !target.type || target.type !== 'checkbox' ) {
        // run your code
    }
}

除了复选框上的那些点击之外,这将触发任何点击的处理程序。