91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

React冒泡和阻止冒泡的使用方法

發布時間:2020-08-19 10:37:41 來源:億速云 閱讀:968 作者:小新 欄目:開發技術

這篇文章給大家分享的是有關React冒泡和阻止冒泡的使用方法的內容。小編覺得挺實用的,因此分享給大家做個參考。一起跟隨小編過來看看吧。

阻止事件冒泡分三種:

1:阻止合成事件往最外層document上的事件冒泡,用e.nativeEvent.stopImmediatePropagation();

2: 合成事件間的冒泡,使用 e.stopPropagation();

3:阻止合成事件,往處理document上的其他原生事件冒泡,需要通過e.target來判斷,示例代碼如下。

import React,{ Component } from 'react';
import ReactDOM,{findDOMNode} from 'react-dom';

class Counter extends Component{
constructor(props){
super(props);

this.state = {
count:0,
    }
  }

handleClick(e){
this.setState({count:++this.state.count});
  }
render(){
return(
<div ref="test">
<p>{this.state.count}</p>
<a ref="update" onClick={(e)=>this.handleClick(e)}>更新</a>
</div>
    )
  }

componentDidMount() {
document.body.addEventListener('click',e=>{
// 通過e.target判斷阻止冒泡
      if(e.target&&e.target.matches('a')){
return;
      }
console.log('body');
    })
  }
}

var div1 = document.getElementById('content');

ReactDOM.render(<Counter/>,div1,()=>{});

需求

最近在寫react的項目,需要手寫一個自定義的菜單,和antd的menu不同,需要點擊一級菜單后彈出類似一個Drawer展示二級和三級菜單,且菜單樣式自定義,都在一個Drawer里展示。

難點

其中難點在于點擊一級菜單時彈出Drawer,點擊除Drawer和一級菜單項之外的dom,Drawer收起。

問題

乍一想就是給document添加一個點擊事件監聽,給Drawer和一級菜單添加阻止冒泡,思路確實如此,后面實現中發現:
react為提高性能,有自己的一套事件處理機制,相當于將事件代理到全局進行處理,也就是說監聽函數并未綁定到Dom上。 因此阻止react的事件冒泡e.stopPropagation(),就不發阻止原生事件的冒泡,表現為點擊Drawer也會收起Drawer;禁用原生事件冒泡e.nativeEvent.stopPropagation(),React的監聽函數就調用不到,表現為點擊Drawer以外dom,Drawer不會收起。這些都不是我們想要的。

解決方案

正確的姿勢應該是判斷event.target對象是否是目標對象或包含目標對象或被包含目標對象,以此來決定是否觸發事件

 componentDidMount() {
  document.addEventListener('click', this.hideDrawer);
 }

 componentWillUnmount() {
  document.removeEventListener('click', this.hideDrawer);
 }

 hideDrawer = e => {
  const { closeDrawer } = this.props;
  // 找到不需要關閉的dom 一級菜單
  const tabContent = document.querySelectorAll('.ant-menu-submenu-vertical');
  // 找到不需要關閉的dom   Drawer
  const drawerContent = document.querySelector('#menuDrawer');
  // 判斷當前點擊的dom對象有沒有包含在目標dom中
  const isHave = Array.from(tabContent).some(item => item.contains(e.target));
  // 不包含則關閉Drawer 包含就走其他的業務邏輯了
  if (tabContent !== null && !(isHave || drawerContent.contains(e.target))) {
   closeDrawer();
  }
 };

感謝各位的閱讀!關于React冒泡和阻止冒泡的使用方法就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

贵阳市| 佳木斯市| 两当县| 将乐县| 繁峙县| 漾濞| 施秉县| 桂东县| 金山区| 通渭县| 江油市| 山西省| 新丰县| 光泽县| 库车县| 温州市| 北海市| 九龙县| 舟曲县| 正镶白旗| 西畴县| 永年县| 泗水县| 田林县| 丹凤县| 绥德县| 蓬溪县| 余庆县| 溧阳市| 隆化县| 鄂温| 建水县| 汉寿县| 绥化市| 昌吉市| 都匀市| 绩溪县| 香河县| 云安县| 千阳县| 南通市|