色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術文章
文章詳情頁

深入了解React中的合成事件

瀏覽:72日期:2022-06-01 11:52:30

1 事件三個階段 捕獲、目標、處理 (具體百度,后面有空補全)

2 示例

import React from "react"; class Test extends React.Component {  parentRef;  childRef;  constructor(props) {    super(props);    this.parentRef = React.createRef();    this.childRef = React.createRef();  }  componentDidMount() {    document.addEventListener(      "click",      () => {console.log(`document原生事件捕獲`);      },      true    );    document.addEventListener("click", () => {      console.log(`document原生事件冒泡`);    });    this.parentRef.current.addEventListener(      "click",      () => {console.log(`父元素原生事件捕獲`);      },      true    );    this.parentRef.current.addEventListener("click", () => {      console.log(`父元素原生事件冒泡`);    });    this.childRef.current.addEventListener(      "click",      () => {console.log(`子元素原生事件捕獲`);      },      true    );    this.childRef.current.addEventListener("click", () => {      console.log(`子元素原生事件冒泡`);    });  }  handleParentBubble = () => {    console.log(`父元素React事件冒泡`);  };  handleChildBubble = (e) => {    console.log(`子元素React事件冒泡`);  };  handleParentCapture = () => {    console.log(`父元素React事件捕獲`);  };  handleChileCapture = () => {    console.log(`子元素React事件捕獲`);  };  render() {    return (      <divref={this.parentRef}onClick={this.handleParentBubble}onClickCapture={this.handleParentCapture}      ><div  ref={this.childRef}  onClick={this.handleChildBubble}  onClickCapture={this.handleChileCapture}>  事件處理測試</div>      </div>    );  }} export default Test;

執行順序

只留子元素修改代碼

import React from "react"; class Test extends React.Component {  parentRef;  childRef;  constructor(props) {    super(props);    this.parentRef = React.createRef();    this.childRef = React.createRef();  }  componentDidMount() {    document.addEventListener(      "click",      () => {console.log(`document原生事件捕獲`);      },      true    );    document.addEventListener("click", () => {      console.log(`document原生事件冒泡`);    });    // this.parentRef.current.addEventListener(    //   "click",    //   () => {    //     console.log(`父元素原生事件捕獲`);    //   },    //   true    // );    // this.parentRef.current.addEventListener("click", () => {    //   console.log(`父元素原生事件冒泡`);    // });    this.childRef.current.addEventListener(      "click",      () => {console.log(`子元素原生事件捕獲`);      },      true    );    this.childRef.current.addEventListener("click", () => {      console.log(`子元素原生事件冒泡`);    });  }  // handleParentBubble = () => {  //   console.log(`父元素React事件冒泡`);  // };  handleChildBubble = (e) => {    console.log(`子元素React事件冒泡`);  };  // handleParentCapture = () => {  //   console.log(`父元素React事件捕獲`);  // };  handleChileCapture = () => {    console.log(`子元素React事件捕獲`);  };  render() {    return (      <divref={this.childRef}onClick={this.handleChildBubble}onClickCapture={this.handleChileCapture}      >事件處理測試      </div>    );    return (      <divref={this.parentRef}onClick={this.handleParentBubble}onClickCapture={this.handleParentCapture}      ><div  ref={this.childRef}  onClick={this.handleChildBubble}  onClickCapture={this.handleChileCapture}>  事件處理測試</div>      </div>    );  }} export default Test;

document原生事件捕獲--》子元素React事件捕獲--》子元素原生事件捕獲--》子元素原生事件冒泡--》子元素React事件冒泡--》document原生事件冒泡

從這個執行順序來看,react事件捕獲執行比原生事件捕獲早,但是原生事件冒泡執行比react事件冒泡快。

所有的react捕獲事件執行完畢之后才會去執行原生的捕獲事件(document原生事件捕獲最先執行)

3 子元素阻止react事件冒泡

e.stopPropagation();

import React from "react"; class Test extends React.Component {  parentRef;  childRef;  constructor(props) {    super(props);    this.parentRef = React.createRef();    this.childRef = React.createRef();  }  componentDidMount() {    document.addEventListener(      "click",      () => {console.log(`document原生事件捕獲`);      },      true    );    document.addEventListener("click", () => {      console.log(`document原生事件冒泡`);    });    this.parentRef.current.addEventListener(      "click",      () => {console.log(`父元素原生事件捕獲`);      },      true    );    this.parentRef.current.addEventListener("click", () => {      console.log(`父元素原生事件冒泡`);    });    this.childRef.current.addEventListener(      "click",      () => {console.log(`子元素原生事件捕獲`);      },      true    );    this.childRef.current.addEventListener("click", () => {      console.log(`子元素原生事件冒泡`);    });  }  handleParentBubble = () => {    console.log(`父元素React事件冒泡`);  };  handleChildBubble = (e) => {    e.stopPropagation();    console.log(`子元素React事件冒泡`);  };  handleParentCapture = () => {    console.log(`父元素React事件捕獲`);  };  handleChileCapture = () => {    console.log(`子元素React事件捕獲`);  };  render() {    return (      <divref={this.parentRef}onClick={this.handleParentBubble}onClickCapture={this.handleParentCapture}      ><div  ref={this.childRef}  onClick={this.handleChildBubble}  onClickCapture={this.handleChileCapture}>  事件處理測試</div>      </div>    );  }} export default Test;

執行順序

e.stopPropagation()只能阻止react合成事件的冒泡和document原生事件冒泡,并不能阻止自己和父元素原生事件的冒泡。

e.nativeEvent.stopImmediatePropagation()只能阻止document原生事件冒泡。

e.preventDefault()和不執行一樣

e.nativeEvent.stopPropagation()只能阻止document原生事件冒泡。

如果我們在子原生的原聲事件里面阻止冒泡,都阻止了。

import React from "react"; class Test extends React.Component {  parentRef;  childRef;  constructor(props) {    super(props);    this.parentRef = React.createRef();    this.childRef = React.createRef();  }  componentDidMount() {    document.addEventListener(      "click",      () => {console.log(`document原生事件捕獲`);      },      true    );    document.addEventListener("click", () => {      console.log(`document原生事件冒泡`);    });    this.parentRef.current.addEventListener(      "click",      () => {console.log(`父元素原生事件捕獲`);      },      true    );    this.parentRef.current.addEventListener("click", () => {      console.log(`父元素原生事件冒泡`);    });    this.childRef.current.addEventListener(      "click",      () => {console.log(`子元素原生事件捕獲`);      },      true    );    this.childRef.current.addEventListener("click", (e) => {      e.stopPropagation();      console.log(`子元素原生事件冒泡`);    });  }  handleParentBubble = () => {    console.log(`父元素React事件冒泡`);  };  handleChildBubble = (e) => {    console.log(`子元素React事件冒泡`);  };  handleParentCapture = () => {    console.log(`父元素React事件捕獲`);  };  handleChileCapture = () => {    console.log(`子元素React事件捕獲`);  };  render() {    return (      <divref={this.parentRef}onClick={this.handleParentBubble}onClickCapture={this.handleParentCapture}      ><div  ref={this.childRef}  onClick={this.handleChildBubble}  onClickCapture={this.handleChileCapture}>  事件處理測試</div>      </div>    );  }} export default Test;

執行順序

在子元素的原聲事件里面,阻止了所有的冒泡。同時也阻止了react事件。

在父元素原生事件中阻止冒泡

import React from "react"; class Test extends React.Component {  parentRef;  childRef;  constructor(props) {    super(props);    this.parentRef = React.createRef();    this.childRef = React.createRef();  }  componentDidMount() {    document.addEventListener(      "click",      () => {console.log(`document原生事件捕獲`);      },      true    );    document.addEventListener("click", () => {      console.log(`document原生事件冒泡`);    });    this.parentRef.current.addEventListener(      "click",      () => {console.log(`父元素原生事件捕獲`);      },      true    );    this.parentRef.current.addEventListener("click", (e) => {      e.stopPropagation();      console.log(`父元素原生事件冒泡`);    });    this.childRef.current.addEventListener(      "click",      () => {console.log(`子元素原生事件捕獲`);      },      true    );    this.childRef.current.addEventListener("click", (e) => {      console.log(`子元素原生事件冒泡`);    });  }  handleParentBubble = () => {    console.log(`父元素React事件冒泡`);  };  handleChildBubble = (e) => {    console.log(`子元素React事件冒泡`);  };  handleParentCapture = () => {    console.log(`父元素React事件捕獲`);  };  handleChileCapture = () => {    console.log(`子元素React事件捕獲`);  };  render() {    return (      <divref={this.parentRef}onClick={this.handleParentBubble}onClickCapture={this.handleParentCapture}      ><div  ref={this.childRef}  onClick={this.handleChildBubble}  onClickCapture={this.handleChileCapture}>  事件處理測試</div>      </div>    );  }} export default Test;

執行順序

父元素原生事件中阻止冒泡阻止了react事件

阻止document原生事件的冒泡并不會阻止了react事件

 document.addEventListener("click", (e) => {      e.stopPropagation();      console.log(`document原生事件冒泡`); });

結論

react捕獲事件快于原生捕獲事件的執行

react冒泡事件慢于原生冒泡事件的執行

原生冒泡事件會阻止react事件。

以上就是深入了解React中的合成事件的詳細內容,更多關于React合成事件的資料請關注其它相關文章!

標簽: JavaScript
主站蜘蛛池模板: 国产成人综合高清在线观看 | 久久骚 | aaaaaa精品视频在线观看 | 欧美一区中文字幕 | 久久国产精品免费观看 | 奇米四色综合久久天天爱 | 欧美一级网站 | 国产成人高清视频在线观看免费97 | 亚洲成人一级 | 久久男人天堂 | 成人一级网站 | 精品国产90后在线观看 | 岛国精品成人 | 全部免费的毛片在线看美国 | 黄色网址网站 | 欧美特黄一级aa毛片 | 91精品国产欧美一区二区 | 欧美日韩一级大片 | 一本综合久久国产二区 | 一区二区三区免费视频 www | 亚洲免费久久 | 怡红院免费全部视频在线视频 | 成人伊人青草久久综合网 | 美国一级毛片免费看 | 久草视频福利 | 亚洲成人精品 | 亚洲色欧美 | 艳女伦交一级毛片 | 国产极品精频在线观看 | 欧美成人高清性色生活 | 成人欧美一区二区三区在线 | 爽爽在线 | 成人精品网 | m男亚洲一区中文字幕 | 免费国产视频在线观看 | 一二三中文乱码亚洲乱码 | 久久久www免费人成看片 | 免费一级欧美大片在线观看 | 狠色狠狠色狠狠狠色综合久久 | 一区视频 | 久久久久久久久久久久久久久久久久 |