我有这个设置
<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();”
但这似乎什么都不做。
答案 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
}
}
除了复选框上的那些点击之外,这将触发任何点击的处理程序。