加入收藏 | 设为首页 | 会员中心 | 我要投稿 湖南网 (https://www.hunanwang.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 编程 > 正文

在React中有很是多的Hooks让我带你深刻相识

发布时间:2021-06-03 01:10:55 所属栏目:编程 来源:互联网
导读:在React中有很是多的Hooks,个中useEffect行使很是频仍,针对一些具有副浸染的函数举办包裹处理赏罚,行使Hook的收益有:加强可复用性、使函数组件有状态 数据获

在React中有很是多的Hooks,个中useEffect行使很是频仍,针对一些具有副浸染的函数举办包裹处理赏罚,行使Hook的收益有:加强可复用性、使函数组件有状态

数据获取、订阅或手动修改DOM都属于副浸染(side effects)。

effect会在React的每次render之后执行,假如是有一些必要同步的副浸染代码,则可以借助useLayoutEffect来包裹,它的用法和useEffect相同

useEffect有两个参数,第一个转达一个函数,第二个参数是作为effect是否执行第一个参数中的函数是否执行的尺度,换句话说,第二个参数数组中的变量是否变革来抉择函数是否执行,函数是否执行依靠于第二个参数的值是否变革。在React中的较量是一个shallow equal(浅较量),对付深条理的工具嵌套,无法精确判定是否产生变革。

useEffect借助了JS的闭包机制,可以说第一个参数就是一个闭包函数,它处在函数组件的浸染域中,同时可以会见个中的局部变量和函数。

多个useEffect串联,按照是否执行函数(依靠项值是否变革),依次挂载到执行链上

在类组件中,有生命周期的观念,在一些讲react hooks的文章中经常会看到怎样借助useEffect来模仿 componentDidmount和 componentUnmount的例子,其第二个参数是一个空数组[],这样effect在组件挂载时辰执行一次,卸载的时辰执行一下return的函数。也同样是闭包的相关,通过return一个函数,来实现闭包以及在React下次运行effect之前执行该return的函数,用于破除副浸染。

(编辑:湖南网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    热点阅读