欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

React冒泡和阻止冒泡的應(yīng)用詳解

 更新時間:2020年08月18日 10:28:00   作者:Tower吖  
這篇文章主要介紹了React冒泡和阻止冒泡的應(yīng)用詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

阻止事件冒泡分三種:

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

解決方案

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

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

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

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

到此這篇關(guān)于React冒泡和阻止冒泡的應(yīng)用詳解的文章就介紹到這了,更多相關(guān)React冒泡和阻止冒泡內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家! 

您可能感興趣的文章:

相關(guān)文章

  • create-react-app修改為多頁面支持的方法

    create-react-app修改為多頁面支持的方法

    本篇文章主要介紹了create-react-app修改為多頁面支持的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-05-05
  • 詳解React?Native項目中啟用Hermes引擎

    詳解React?Native項目中啟用Hermes引擎

    這篇文章主要為大家介紹了React?Native項目中啟用Hermes引擎實例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-09-09
  • React父組件調(diào)用子組件中的方法實例詳解

    React父組件調(diào)用子組件中的方法實例詳解

    最近做一個React項目,所有組件都使用了函數(shù)式組件,遇到一個父組件調(diào)用子組件方法的問題,下面這篇文章主要給大家介紹了關(guān)于React父組件調(diào)用子組件中方法的相關(guān)資料,文中通過實例代碼介紹的非常詳細,需要的朋友可以參考下
    2022-07-07
  • 解讀react的onClick自動觸發(fā)等相關(guān)問題

    解讀react的onClick自動觸發(fā)等相關(guān)問題

    這篇文章主要介紹了解讀react的onClick自動觸發(fā)等相關(guān)問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-02-02
  • react?路由權(quán)限動態(tài)菜單方案配置react-router-auth-plus

    react?路由權(quán)限動態(tài)菜單方案配置react-router-auth-plus

    這篇文章主要為大家介紹了react路由權(quán)限動態(tài)菜單方案react-router-auth-plus傻瓜式配置詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-08-08
  • 淺析React中的受控組件和非受控組件

    淺析React中的受控組件和非受控組件

    具體來說這是一種react非受控組件,其狀態(tài)是在input的react內(nèi)部控制,不受調(diào)用者控制。可以使用受控組件來實現(xiàn)。下面就說說這個React中的受控組件與非受控組件的相關(guān)知識,感興趣的朋友一起看看吧
    2021-05-05
  • react16.8.0以上MobX在hook中的使用方法詳解

    react16.8.0以上MobX在hook中的使用方法詳解

    這篇文章主要為大家介紹了react16.8.0以上MobX在hook中的使用方法詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-07-07
  • React Native中TabBarIOS的簡單使用方法示例

    React Native中TabBarIOS的簡單使用方法示例

    最近在學習過程中遇到了很多問題,TabBarIOS的使用就是一個,所以下面這篇文章主要給大家介紹了關(guān)于React Native中TabBarIOS簡單使用的相關(guān)資料,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考下。
    2017-10-10
  • 深入理解React中Suspense與lazy的原理

    深入理解React中Suspense與lazy的原理

    在react中為我們提供了一個非常有用的組件,那就是Suspense,本文主要介紹了如何使用Suspense?和?react提供的lazy結(jié)合起來達到異步加載狀態(tài)的目的,感興趣的可以了解下
    2024-04-04
  • Next.js搭建Monorepo組件庫文檔實現(xiàn)詳解

    Next.js搭建Monorepo組件庫文檔實現(xiàn)詳解

    這篇文章主要為大家介紹了Next.js搭建Monorepo組件庫文檔,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-11-11

最新評論