Я пытаюсь использовать event.stopPropagation () в компоненте ReactJS, чтобы остановить событие щелчка от всплытия и запуска события щелчка, которое было прикреплено с JQuery в устаревшем коде, но похоже, что stopPropagation () React только останавливает распространение на события также прикреплен к React, а stopPropagation () JQuery не останавливает распространение событий, связанных с 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
чтобы предотвратить запуск других прослушивателей событий, но порядок выполнения не гарантируется.