react中常用的两个hook是什么-亚博电竞手机版

react中常用的两个hook是什么

这篇文章给大家分享的是有关react中常用的两个hook是什么的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。

先介绍一下什么是hook

hook是react 16.8新增的特性,专门用在函数式组件,它可以代替class组件中react的其他特性,是实际工作中要常用到的。

为什么推荐使用hook进行开发

hook是专门配合函数式组件开发使用的,可以用它代替class组件的一些生命周期,避免大量this引起的混乱,因此hook便于开发,且更易于让开发者理解代码

以上是个人的简单总结,更多原因可以参考react亚博电竞手机版官网:

https://react.docschina.org/docs/hooks-intro.html#motivation

usestate

代码中:

react.usestate(0)相当于class组件中的this.state添加一个属性值

variable相当于class组件中的this.state. variable的值

setvariable可以用来修改variable的值,可以相当于class组件中的this.setstate

importreact,(usestate)from'react'exportdefaultfunctionusestate_demo(){const[variable,setvariable]=usestate(0);//通过解构赋值,我们拿到的variable、setvariablefunctionchangevariable(){setvariable((variable)=>variable 1)//setvariable的回调中传进来的参数是variable}render(

点我会使variable 1
)}

useeffect

代码中:

以下代码中可以看出,useeffect的使用代替了在class组件中componentdidmoun、componentdidupdate、componentwillunmount的使用

importreact,(usestate,useeffect)from'react'exportdefaultfunctionusestate_demo(){const[variable,setvariable]=usestate(0);//通过解构赋值,我们拿到的variable、setvariableuseeffect(()=>{//这个return是在该组件监测的数据变化时或者被卸载时调用的,被卸载时调用可以相当于componentwillunmount钩子return()=>{console.log('该组件被卸载了')}},[variable])//第二个参数传了[variable],表示检测variable的更新变化,一旦variable变化就会再次执行useeffect的回调//第二个参数传了[],表示谁都不检测只执行一次useeffect的回调,相当于componentdidmount钩子//第二个参数不传参,只要该组件有state变化就会执行useeffect的回调,相当于componentdidupdate钩子functionchangevariable(){setvariable((variable)=>variable 1)//setvariable的回调中传进来的参数是variable}render(

点我会使variable 1
)}

使用hook需要注意的

1、只在组件函数的最外层使用hook,不要在循环,条件或嵌套函数中调用 hook

importreact,(useeffect)from'react'exportdefaultfunctionusestate_demo(){//这里才是正确的useeffect(()=>{})//错误1,使用了条件判断if(true){useeffect(()=>{})}//错误2,使用了循环while(true){useeffect(()=>{})}//错误3,使用了嵌套useeffect(()=>{useeffect(()=>{})})}

2、不能在组件的函数外使用hook

importreact,(usestate,useeffect)from'react'//错误1,在组件函数外使用了usestateconst[variable,setvariable]=usestate(0);//错误2,在组件函数外使用了useeffectuseeffect(()=>{})exportdefaultfunctionusestate_demo(){//在组件函数里使用才是正确的const[variable,setvariable]=usestate(0);}

3、为了避免以上的错误,可以 安装eslint-plugin-react-hooks eslint 插件来检查代码上错误

自定义hook

hook就是一个函数,自定义hook是为了方便组件之间共享逻辑,其实就是对复用功能进行封装,自定义hook内部也调用了react自带的hook,命名要以use开头

//自定义hookfunctionusehook(initstate){const[variable,setvariable]=usestate(initstate)returnvariable;}//使用自定义hookexportdefaultfunctionusestate_demo(){constvariablestate=usehook(0)}

可能你会疑惑,多个组件中使用相同的 hook 会共享 state 吗?

答案是:不会。因为每次调用react自带的hook都是独自互不影响的,所以自定义hook被多次重复调用也是独自互不影响的

感谢各位的阅读!关于“react中常用的两个hook是什么”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,让大家可以学到更多知识,如果觉得文章不错,可以把它分享出去让更多的人看到吧!

展开全文
内容来源于互联网和用户投稿,文章中一旦含有亚博电竞手机版的联系方式务必识别真假,本站仅做信息展示不承担任何相关责任,如有侵权或涉及法律问题请联系亚博电竞手机版删除

最新文章

网站地图