Próbuję użyć zdarzenia event.stopPropagation () w komponencie ReactJS, aby zatrzymać propagację zdarzenia kliknięcia i wyzwolenie zdarzenia kliknięcia, które zostało dołączone do JQuery w starszym kodzie, ale wygląda na to, że stopPropagation () Reacta zatrzymuje tylko propagację do zdarzeń również dołączony w Reakcie, a stopPropagation () JQuery nie zatrzymuje propagacji do zdarzeń dołączonych do React.
Czy istnieje sposób, aby funkcja stopPropagation () działała w przypadku tych zdarzeń? Napisałem prosty JSFiddle, aby zademonstrować następujące zachowania:
/** @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();
});
});
stopImmediatePropagationdetektory zdarzeń roszczeń będą wywoływane w kolejności, w jakiej zostały powiązane. Jeśli twój React JS został zainicjowany przed twoim jQuery (tak jak na twoich skrzypcach), zatrzymanie natychmiastowej propagacji zadziała.
componentDidMount, ale może to kolidować z innymi programami obsługi zdarzeń React w nieoczekiwany sposób.
.stop-propagationnie zadziała. Twój przykład używa delegowania zdarzeń, ale próbuje zatrzymać propagację w elemencie. Słuchacz musi być związany z samego elementu: $('.stop-propagation').on('click', function(e) { e.stopPropagation(); });. To skrzypce zapobiega wszelkiej propagacji, tak jak próbowałeś: jsfiddle.net/7LEDT/6
event.nativeEvent.stopImmediatePropagationaby zapobiec uruchamianiu innych detektorów zdarzeń, ale kolejność wykonywania nie jest gwarantowana.