javascript - react 中绑定事件和阻止事件冒泡
问题描述
直接上代码吧,我是想了半天不知道哪里出问题了。
state = {spread: false } componentDidMount() {console.log(’document clicked’)document.onclick = () => { if(this.state.spread) {this.setState({ spread: false}) }} } spreadHandler (e) {console.log(’target clicked’)// 这个事件绑定在一个 a 标签上e.stopPropagation()this.setState({ spread: !this.state.spread}) }
这个功能就是一个类似淘宝顶部导航条的功能,只不过我这里用的是点击事件。现在我触发spreadHandler的时候取消了冒泡,但是document的click事件还是会触发。不知道是因为事件绑定在 a 标签上,还是别的什么原因造成的,有人知道这是怎么回事吗?
问题解答
回答1:react 的合成事件中的阻止冒泡, 是无法取消原生事件冒泡的.原生事件中阻止冒泡行为, 反而可以阻止 react 合成事件中的冒泡.所以应该尽量避免混用, 非用不可的话, 可以在 document 的事件处理程序中加一层判断.
document.addEventListener(’click’, function(e){ // 类似事件委托, 判断一下发生事件的元素. if( e.target.nodeName.toLowerCase() === ’a’ ) {return; }}, false);回答2:
e.preventDeafult()
回答3:试试这个:
e.nativeEvent.stopImmediatePropagation();
react的事件机制与原生js的事件机制是有所区别的。
回答4:react的合成事件都是通过绑定在document上click的事件代理实现的,所以无法通过阻止合成事件冒泡(已将冒到document上了)来阻止docuemnt上的其他事件处理,所以得用原生事件
相关文章:
1. android - 哪位大神知道java后台的api接口的对象传到前端后输入日期报错,是什么情况?求大神指点2. 我何时应该在Java中使用JFrame.add(component)和JFrame.getContentPane()。add(component)3. mysql 5个left关键 然后再用搜索条件 几千条数据就会卡,如何解决呢4. node.js - webpack-dev-server正常运行,webpack打包却出错,怎么办?5. javascript - 项目的公共文件如图片JS等文件放在 云上,webroot只放jsp文件,怎么将静态文件通过配置文件引入,sp求大神指导6. 这是什么情况???7. thinkphp3 count()方法必须加上字段?8. 关于用java中正则表达式匹配单个字符9. 怎么php怎么通过数组显示sql查询结果呢,查询结果有多条,如图。我要forsearch里面echo10. python中return 语句与 分支语句连用问题
