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

新世纪建设集团网站建筑项目查询平台

新世纪建设集团网站,建筑项目查询平台,长沙seo网站建设,自己做电台直播的网站什么是副作用操作? useEffect 用于编写由渲染本身引起的对接组件外部的操作(官方称呼为:副作用操作) 以下情况会触发页面渲染 初次加载页面(组的挂载)响应式变量发生变化,触发页面根据新值重新…

什么是副作用操作?

useEffect 用于编写由渲染本身引起的对接组件外部的操作(官方称呼为:副作用操作)

以下情况会触发页面渲染

  • 初次加载页面(组的挂载)
  • 响应式变量发生变化,触发页面根据新值重新渲染(组件更新)
  • 关闭页面(组件卸载)

以下情况需要添加副作用操作

  • 页面初步渲染完成后,向服务器获取数据完成页面的最终渲染
  • 响应式变量发生变化时,先根据新值执行必要的其他业务逻辑,再进行最终的页面更新渲染
  • 关闭页面时,关闭定时器

useEffect 语法

useEffect 是 hook 函数

  • 第一个参数(必要): 自定义的处理函数(官方称呼为:副作用函数)
  • 第二个参数(可选): 依赖项

在这里插入图片描述

无依赖项

执行副作用函数的时机

  • 组件初次渲染后(组件挂载完成),在开发环境,会执行两次,生产环境仅执行一次
  • 组件更新渲染前(任一响应式变量变化都会触发!)
import { useEffect } from "react";function Demo() {useEffect(() => {console.log("执行了副作用函数");});return (<><div>你好</div></>);
}export default Demo;

依赖项为空数组 []

类似 vue 的生命周期 mounted

执行副作用函数的时机

  • 组件初次渲染后(组件挂载完成),在开发环境,会执行两次,生产环境仅执行一次
import { useEffect } from "react";function Demo() {useEffect(() => {console.log("执行了副作用函数");}, []);return (<><div>你好</div></>);
}export default Demo;

使用场景
初次渲染页面时访问接口加载页面数据

import { useEffect, useState } from "react";
import axios from "axios";function Demo() {const [list, setList] = useState([]);useEffect(() => {async function getList() {const res = await axios.get("http://localhost:3000/dataList");setList(res.data);}getList();}, []);return (<>{list.map((item) => (<div key={item.id}>{item.title}</div>))}</>);
}export default Demo;

依赖项为响应式变量构成的数组

类似 vue 的立即执行侦听器 watch

执行副作用函数的时机

  • 组件初次渲染后(组件挂载完成),在开发环境,会执行两次,生产环境仅执行一次
  • 响应式变量发生变化触发页面进行更新渲染前
import { useEffect, useState } from "react";function Demo() {const [name, setName] = useState("朝阳");useEffect(() => {// 在挂载和 name 更新时,都会执行!console.log("当前name值为:", name);}, [name]);function changeName() {setName("晚霞");}return (<><button onClick={changeName}>改名字</button></>);
}export default Demo;

清除副作用

最经典的场景即在组件卸载时清除计时器,以免内存泄露

father.jsx

import { useState } from "react";
import Child from "./child.jsx";function Father() {const [ifChild, setIfChild] = useState(true);function removeChild() {setIfChild(false);}return (<><button onClick={removeChild}>移除子组件</button>{ifChild && <Child />}</>);
}export default Father;

child.jsx

import { useEffect } from "react";function Child() {useEffect(() => {// 添加定时器const timer = setInterval(() => {console.log("执行了定时器");}, 1000);return () => {// 清除定时器clearInterval(timer);};});return (<><div><h1>我是子组件</h1></div></>);
}export default Child;
http://www.yayakq.cn/news/145906/

相关文章:

  • 做微信公众号海报的网站做门户网站源码
  • 免费w网站建设数字中国建设峰会 官方网站
  • 网站自动生成centos 下载wordpress
  • 网上购物网站设计做网站商城开发什么语言最快
  • 郑州市公司网站开发设计好口碑自适应网站建设
  • 做标书要不要做网站建设网页建设
  • 网站seo基本流程长沙最新死亡事件
  • 网站建设辶金手指排名十一计算机应用技术(网站开发)
  • 建一个网站 服务器机房托管价格携程官网
  • 商丘网站建设案例wordpress404页面
  • 伊川网站开发湖南百度推广
  • joomla适合做什么网站网站建设从零开始 教程
  • 专业做网站哪里有旅游景点网站建设毕业设计说明
  • dedecms图片网站模板大连开发区招聘网站
  • 找设计师做网站个人视频网站源码
  • 在上海做钟点工的网站国家开发公司
  • 电子商城网站开发购物车莱芜网络公司网站
  • 推荐家居企业网站建设微网站预览
  • 电子商务网站建设与管理a创意设计网站大全
  • 深圳印刷网站建设wordpress手机版弹出式导航
  • 建设通网站怎么查项目经理在建网站建设需求原型
  • 网站托管jquery插件网站推荐
  • 东莞邦邻网站建设做网站卖资料
  • 准备php和易语言混编做网站外贸商城网站开发
  • 音乐网站页面设计凡客登录
  • 江苏中淮建设集团有限公司网站企业营销型网站有特点
  • 用数字做域名网站狂人采集器 wordpress
  • 做网站设置时间营销型网站建设明细报
  • wordpress企业建站流程建设部注册师网站
  • o2o商城网站制作重庆企业网站建设