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

房屋出租网站模板北京本地网络推广平台

房屋出租网站模板,北京本地网络推广平台,开网店的流程操作步骤,web网站开发步骤1、概述 useEffect 是React中一个用于 将组件与外部系统同步的 Hook;在函数式组件中处理副作用函数的 Hook,用于替代类式组件中的生命周期函数; 可以在副作用函数中 实现以下操作: a、请求接口,获取后台提供数据 b、操…

1、概述

useEffectReact中一个用于 将组件与外部系统同步的 Hook;在函数式组件中处理副作用函数的 Hook,用于替代类式组件中的生命周期函数
可以在副作用函数中 实现以下操作:
a、请求接口,获取后台提供数据
b、操作DOM
c、事件监听window.addEventListener()
d、清理任务; clearInterval()

如果没有与外部系统链接,或许可以不使用 useEffect

2、写法

useEffect(fnc, dependencies)

第一个参数fnc 是一个副作用函数,即在执行的过程中会影响组件的其他属性,而不是纯函数,纯函数是没有参数,输入相同的时候,输出也是相同的;
第二个参数可选参数:dependencies 是副作用函数执行的依赖项数组,可以是空数组,a/当为空数组时候,组件只会在初次渲染的时候,触发副作用函数执行;b/当不传依赖项时候,每次组件渲染都会触发副作用函数执行;c/依赖项可以是 props、state

当:fnc 中 return () => {} 时,这里执行的是组件卸载时候的逻辑;

2.1、依赖项不传

每次渲染都会触发副作用函数, 类似于类式组件中的 componentDidUpdate 钩子

useEffect(() => {console.log('==视图更新了=')
})
2.2、依赖项传入空数组

只有在第一次挂载时候才会触发副作用函数,类似于类式组件componentDidMount 钩子

useEffect(() => {console.log('=只有挂载=更新了=')
}, [])
2.3、依赖指定属性时

当属性 name 变化时候,就会触发副作用函数,类似于类式组件中的 componentDidUpdate 钩子

const [name, setName] = useState('Andy')
useEffect(() => {console.log('=只有name 属性变化时=更新了=')
},[name])
2.4、副作用函数中传入 回调函数时

此时,类似于 类式组件componentWillUnmount 钩子
可以在这里清除定时任务,销毁DOM结构、移除事件监听

useEffect(() => {return () => {console.log('====组件将要卸载了=')}
}, [name])
2.5、清除定时任务
import { useEffect, useState } from 'react'
export default function index() {const [count, setCount] = useState(0)const [name, setName] = useState('Andy')const handleChangeName = () => {setName(`${name} + &`)}let timer = nullconst handleChangeTime = () => {console.log('==开始计数了=')timer = setInterval(() => {setCount((count) => count + 1)}, 500)}useEffect(() => {return () => {// 清除定时任务clearInterval(timer)console.log('==计数结束了=')}}, [name])
return (<div><h3>useEffect text demo .</h3><p>名称:{name}</p><button onClick={handleChangeName}>清除定时任务</button><hr /><p>计数器:{count}</p><button onClick={handleChangeTime}>计时开始</button></div>)
}
2.6、清除事件监听
useEffect(() => {// 组件挂载 监听视图窗口变化const resize = () => console.log('窗口大小变化');window.addEventListener('resize', resize);return() => {window.removeEventListener('resize', resize)}
}, [])
2.7、死循环

禁止useEffect 中使用 useState 的SetXxx 函数, 更新useEffect 中的依赖项
否则会导致进入死循环

 useEffect(() => {// 死循环const timer = setInterval(() => {console.log('==计数进行中=', count, count)setCount(count + 1)}, 500)return () => {clearInterval(timer)console.log('==计数结束了=')}
},[count, name])

3、注意事项:

1、依赖项为引用类型时,React 会对比前后地址(引用指针)是否一致,如果一致 Effect 则不会重新渲染
2、避免使用更新依赖时产生死循环
3、组件中使用的定时任务,需要在组件卸载时候清除,避免导致内存溢出
4、依赖项避免过多,会导致追踪复杂化,或者出现意向不到的问题,尽量简化依赖项;

4、useEffectuseMemo 的区域

useMemo 主要用于计算和缓存值,以减少重复昂贵的计算,它返回一个 memoized 值。
useEffect 主要用于处理副作用,例如订阅、数据获取、DOM 操作等,它不返回值,但可以在组件渲染后执行操作。
useMemo 的作用是优化性能,减少不必要的计算,即使没有useMemo 组件同样可以正常执行
useEffect 的目标是处理副作用,管理组件的生命周期
useMemo 的依赖数组用于控制何时重新计算值
useEffect 的依赖数组用于控制何时运行副作用函数

http://www.ds6.com.cn/news/31188.html

相关文章:

  • 有个网站专做品牌 而且价格便宜关键词搜索引擎排名查询
  • 做网站组服务器刷关键词指数
  • 西安网站建设推广优化seo扣费系统源码
  • 响应式网站检测工具开展网络营销的企业
  • 网站建设用户登录qq推广
  • 广西中国建设银行网站首页网站推广优化怎样
  • 司局网站维护廉政风险建设浙江seo
  • 东莞万江网站建设公司网站推广优化
  • 武汉做机床的公司网站国家免费培训学校
  • 惠州品牌网站建设公司哪里有如何找外包的销售团队
  • 腾讯云网站搭建我想自己建立一个网站
  • 福州网站建设方案服务舆情服务公司
  • html5行业网站在线资源搜索神器
  • 2345官网上海网站优化
  • 网站图片链接是怎么做的杭州互联网公司排名榜
  • 徐州好点的做网站的公司专业黑帽seo
  • 工业信息部网站备案网络营销建议
  • 一般通过什么途径当交警优化seo排名
  • phpcms v9网站导航武汉软件测试培训机构排名
  • yellow日本高清免费中文郑州粒米seo外包
  • 做网站别名解析的目的是什么免费域名怎么注册
  • 盐城网站开发天堂网长尾关键词挖掘网站
  • 亚马逊网站开发百度快速收录教程
  • 经典网站模板下载日本域名注册网站
  • 河南网站建设价格大全东营优化公司
  • 淘宝优惠券发布网站怎么做西安网站seo费用
  • 外贸网站交易平台企业网络营销策划书范文
  • 电商网站开发用什么软件好企业网站设计代码
  • 网站设计太原域名注册查询
  • 代办公司注册收费标准南宁百度seo