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

网站型和商城型有什么区别合肥建设局网站

网站型和商城型有什么区别,合肥建设局网站,wordpress新建子域名多站点,中国最大的求购平台什么是副作用操作? 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/964660/

相关文章:

  • 网站广告费一般多少钱seo搜索引擎专员
  • 丰县徐州网站开发网站建设收费报价表
  • 源汇区建设局网站公关到底做什么
  • 网站建设中广告法绝对化用语整理陕煤建设集团韩城分公司网站
  • 企业网站的设计原则wordpress 分类判断
  • 贺州招聘网站建设公积金网站建设模板
  • 初学者做网站的软件php网站开发速成
  • 网站的访问速度和什么有关系软件著作权
  • 岳阳商城网站建设wordpress 30分钟过期
  • 南昌网站优化公司百度竞价是什么意思?
  • 武进网站建设市场景点网站应该怎么做
  • 企业电子商务网站的建设方式广东响应式网站
  • 云南省网站建设开发者选项
  • 零基础网站建设及维护视频课程漯河网站建设e
  • 上海网站建设高端定制网络服务公司做电影网站成本
  • ai可以做网站吗工程设计有限公司
  • 学校网站资源建设方案电子商务网站是什么意思
  • 开发区人才市场招聘信息seo搜索优化培训
  • 湖北高端网站建设价格做视频图片博客网站有哪些
  • 荆州做网站公司最好网络规划设计师教程(第2版)pdf
  • asp怎么样做网站后台扫描二维码进入公司网站怎样做
  • 茂名建站价格iis wordpress index.php
  • 深圳专业医疗网站建设做旅游网站公司
  • 网站页面设计报价公司网站建设方案ppt
  • 网络设备互联课设建设企业网站烟台开发区建设业联合网站
  • 长春百度网站快速优化百度一下照片识别
  • 律师做网络推广哪个网站好wordpress文章页图片尺寸
  • 网站建设招聘条件兰州企业 网站建设
  • 网站开发设计报告重庆平面设计公司
  • 为什么做网站wordpress空间免费下载