【发布时间】:2014-08-16 10:15:26
【问题描述】:
我正在尝试在 ReactJS 组件中使用 event.stopPropagation() 来阻止单击事件冒泡并触发在遗留代码中附加到 JQuery 的单击事件,但似乎 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();
});
});
【问题讨论】:
-
React 的实际事件监听器也在文档的根目录,这意味着点击事件已经冒泡到根目录。您可以使用
event.nativeEvent.stopImmediatePropagation来阻止其他事件侦听器触发,但不保证执行顺序。 -
其实
stopImmediatePropagation声称事件监听器会按照绑定的顺序被调用。如果你的 React JS 在你的 jQuery 之前被初始化(就像它在你的小提琴中一样),停止立即传播将起作用。 -
React 阻止调用 jQuery 侦听器:jsfiddle.net/7LEDT/5 jQuery 无法阻止调用 React,因为 jQuery 侦听器稍后会在您的小提琴中绑定。
-
一种选择是在
componentDidMount中设置您自己的 jQuery 事件处理程序,但它可能会以意想不到的方式干扰其他 React 事件处理程序。 -
我意识到
.stop-propagation上的第二个示例一定行不通。您的示例使用事件委托,但试图在元素处停止传播。侦听器需要绑定到元素本身:$('.stop-propagation').on('click', function(e) { e.stopPropagation(); });。这个小提琴可以防止像您尝试的所有传播:jsfiddle.net/7LEDT/6
标签: javascript jquery reactjs