最佳答案
我正在尝试在 ReactJS 组件中使用 event.stop 繁殖()来阻止一个单击事件冒泡并触发一个在遗留代码中与 JQuery 连接的单击事件,但似乎 React 的 stop 繁殖()只能阻止对同样与 React 连接的事件的传播,而 JQuery 的 stop 繁殖()并不能阻止对与 React 连接的事件的传播。
有没有什么方法可以在这些事件之间使停止繁殖()工作?我写了一个简单的 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();
});
});