我试图在ReactJS组件中使用event.stopPropagation()来阻止单击事件冒泡并触发遗留代码中与JQuery关联的click事件,但是似乎React的stopPropagation()只能停止传播到事件也附加在React中,并且JQuery的stopPropagation()不会停止传播到随React附加的事件。
有什么办法可以使stopPropagation()在这些事件中起作用?我编写了一个简单的JSFiddle来演示这些行为:
/** @jsx React.DOM */
var Propagation = React.createClass({
alert: function(){
alert('React Alert');
},
stopPropagation: function(e){
e.stopPropagation();
},
render: function(){
return (
<div>
<div onClick={this.alert}>
<a href="#" onClick={this.stopPropagation}>React Stop Propagation on React Event</a>
</div>
<div className="alert">
<a href="#" onClick={this.stopPropagation}>React Stop Propagation on JQuery Event</a>
</div>
<div onClick={this.alert}>
<a href="#" className="stop-propagation">JQuery Stop Propagation on React Event</a>
</div>
<div className="alert">
<a href="#" className="stop-propagation">JQuery Stop Propagation on JQuery Event</a>
</div>
</div>
);
}
});
React.renderComponent(<Propagation />, document.body);
$(function(){
$(document).on('click', '.alert', function(e){
alert('Jquery Alert');
});
$(document).on('click', '.stop-propagation', function(e){
e.stopPropagation();
});
});
stopImmediatePropagation
声明事件侦听器将按照绑定的顺序调用。如果您的React JS在jQuery之前进行了初始化(就像在小提琴中一样),则停止立即传播将起作用。
componentDidMount
,但是它可能以意外的方式干扰其他React事件处理程序。
.stop-propagation
行不通的。您的示例使用事件委托,但是试图在元素处停止传播。侦听器需要绑定到元素本身:$('.stop-propagation').on('click', function(e) { e.stopPropagation(); });
。这个小提琴阻止了所有传播,就像您正在尝试的那样:jsfiddle.net/7LEDT/6
event.nativeEvent.stopImmediatePropagation
用来阻止其他事件侦听器触发,但是不能保证执行顺序。