当前位置: 首页 > news >正文

沧州网站制作运营管理培训

沧州网站制作,运营管理培训,3天网站seo优化成为超级品牌,天下房产网React 基础巩固(四十三)——Effect Hook 一、Effect Hook的基本使用 Effect Hook 用来完成一些类似class中生命周期的功能。 在使用类组件时,不管是渲染、网路请求还是操作DOM,其逻辑和代码是杂糅在一起的。例如我们希望把计数器结果显示在标签上&…

React 基础巩固(四十三)——Effect Hook

一、Effect Hook的基本使用

Effect Hook 用来完成一些类似class中生命周期的功能。

在使用类组件时,不管是渲染、网路请求还是操作DOM,其逻辑和代码是杂糅在一起的。例如我们希望把计数器结果显示在标签上,在类组件中,我们通过生命周期进行实现,如下所示:

import React, { PureComponent } from "react";export class App extends PureComponent {constructor() {super();this.state = {counter: 100,};}componentDidMount() {document.title = this.state.counter;}componentDidUpdate() {document.title = this.state.counter;}render() {const { counter } = this.state;return (<div><h2>计数:{counter}</h2><button onClick={(e) => this.setState({ counter: counter + 1 })}>+1</button></div>);}
}export default App;

在函数组件中,我们可以利用useEffect来完成除渲染界面以外的事情,即完成副作用的事情。这样能让代码和逻辑看起来更清晰、简洁:

import React, { memo, useEffect, useState } from "react";export default memo(function App() {const [count, setCount] = useState(200);// 完成一些除渲染外,副作用的事情useEffect(() => {// 当前传入的回调函数会在组件被渲染完成后,自动执行// 网络请求/DOM操作/事件监听document.title = count;});return (<div><h2>计数:{count}</h2><button onClick={(e) => setCount(count + 1)}>+1</button></div>);
});

可以看到,通过useEffect的Hook,能够告知react在渲染后需要执行哪些操作。在react执行完更新DOM操作后,会回调我们在useEffect中传入的回调函数。在默认情况下,这个函数无论是第一次渲染还是每次更新后,均会被调用。

二、需要清除的Effect

在class组件中,我们通常会在componentDidMount中设置监听事件,componentWillUnmount中清除监听事件;而利用useEffect的函数组件中,我们可以通过useEffect的返回值(回调函数)来实现事件监听的清除操作:

import React, { memo, useEffect, useState } from "react";export default memo(function App_clear() {const [count, setCount] = useState(0);// 在执行完渲染后,执行副作用事件useEffect(() => {// 监听事件// const unsubscribe = store.subscribe(() => {});// function foo() {}// eventBus.on("test", foo);// 监听和取消放在一个地方,内聚性高console.log("假设监听unsubscribe、eventBus等事件");// // 返回值:回调函数 => 组件重新渲染或组件卸载时执行return () => {console.log("取消监听unsubscribe、eventBus等事件");};});return (<div><button onClick={(e) => setCount(count + 1)}>+1({count})</button></div>);
});

useEffect中返回的函数,是effect的可选的清除机制,能够实现将设置监听和取消监听的逻辑放在一起,提高内聚性。

image-20230731214407030

三、多个Effect的使用

假设我们在useEffect执行如下三个操作:

  // 在执行完渲染后,执行副作用事件useEffect(() => {// 1.修改document的title// 2.对redux中数据变量的监听// 3.监听eventBus中的事件});

我们会发现,随着事件的增多,useEffect中的逻辑会逐渐复杂,这时我们可以将其拆分为多个effect,依次执行,即react支持多个useEffect:

  // 在执行完渲染后,执行副作用事件useEffect(() => {// 1.修改document的titleconsole.log('1.修改document的title');});useEffect(() => {// 2.对redux中数据变量的监听console.log('2.对redux中数据变量的监听');});useEffect(() => {// 3.监听eventBus中的事件console.log('3.监听eventBus中的事件');});

当我们每次触发页面渲染后,可以看到,三个事件被依次执行:

image-20230731215518004

四、Effect的执行机制

我们发现,每次点击按钮都会执行监听操作,假设effect中是一个网络请求事件,则会在每次更新后发起请求,这样频繁的监听、请求绝对不是我们想要的。我们可以用useEffect的第二个参数来控制其执行机制:

  // 在执行完渲染后,执行副作用事件useEffect(() => {// 1.修改document的titleconsole.log("1.修改document的title");}, [count]);useEffect(() => {// 2.对redux中数据变量的监听console.log("2.对redux中数据变量的监听");}, []);useEffect(() => {// 3.监听eventBus中的事件console.log("3.监听eventBus中的事件");}, []);

当我们传入一个空数组时,意味着该副作用事件不依赖任何内容,此时与componentDidMount的效果一致,只有在第一次加载时,才会执行useEffect:

image-20230731220520078

当我们对于事件1传入[count]时,则意味着事件1所在的useEffect依赖count变量,当count变量发生变化时,则会执行。于是,当我们点击按钮修改count值时,只有事件1会被一次次的触发:

image-20230731220704060

http://www.yayakq.cn/news/951656/

相关文章:

  • 有哪些网站是静态网站wordpress 最近登录地址
  • 微信小程序开发定制公司排名做网站优化
  • 海南网站开发中国购物网站设计欣赏
  • php做网站需要的技术佛山网站建设冯哥
  • 网站架构包括杭州小程序建设公司
  • 小型旅游网站建设方案做平面设计的网站有哪些
  • 怎么做企业招聘网站怎么做网络乞丐网站
  • 手机网站建设报价多少品牌手表网站
  • 做产品的淘宝客网站行情软件app
  • 厦门专业做网站自学网站开发要多久
  • 专业做律师网站的公司建设执业资格注册中心网站
  • 专业网站建设市场分析杭州的网站建设公司
  • 零基础网站建设及维护视频课程友情链接如何添加
  • 上海网站建设过程oppo手机网站建设需求分析
  • 青岛网站制作永诚seo教程从零开始
  • app 与网站温州论坛招聘
  • 网站建设文件上传网站设计开发人员
  • 湖北智能网站建设找哪家自贡彩灯制作公司
  • 现在注册公司多少钱网站优化怎么做效果才好
  • 企业网站建设设计任务书装修公司装饰
  • 建筑材料东莞网站建设如何推荐别人做网站
  • 网站搭建设计方案早期电商平台有哪些
  • 爱用建站下载电子商务实网站的建设课件
  • 做宠物商品的网站网站备案号有什么用
  • 网站做的一样算不算侵权注册城乡规划师考试大纲
  • 专业做二手网站网站建设需要什么工具
  • 百度网盟 网站定向上海有几个区和县
  • 做视频网站新手教学做网站ps的图片
  • 公司网站与营销网站珠海专业网站制作公
  • asp网站301深圳市核酸检测点查询