React函数组件模拟生命周期(useEffect)

摘要:
ReactHooks提供React。useEffect解决功能组件没有生命周期React的问题。使用效果(fn,?

React Hooks提供React.useEffect来解决函数组件没有生命周期的问题

React.useEffect(fn,?)第一个参数是特定实时机执行的回调函数,第二个参数是指依赖项

  1.模拟componentDidMount第一次渲染

useEffect(() => {
    console.log('');
}, []) // 第二个参数为空时只会在第一次渲染时执行

  2. 模拟componentDidUpdate

useEffect(() => {
    console.log('n变化了');
}, [n]) // 第二个参数为要监听的数据

不传第二个参数,则会在 state 的任意一个属性改变时,组件每渲染一次,都会触发该函数回调
useEffect(() => { console.log('任意属性变化'); })

  3,模拟componentWillUnmount

通过函数里返回函数的方式

useEffect(() => {
    console.log('任意属性变了');
    return () => {
        console.log('该组件要销毁了');
    }
})

  useEffect返回值是一个函数,在组件卸载前执行,或每次副效应函数重新执行之前执行

注意:多个副效应

免责声明:文章转载自《React函数组件模拟生命周期(useEffect)》仅用于学习参考。如对内容有疑问,请及时联系本站处理。

上篇第12组 Alpha冲刺 (1/6)(组长)latex 使用中的一些问题下篇

宿迁高防,2C2G15M,22元/月;香港BGP,2C5G5M,25元/月 雨云优惠码:MjYwNzM=

相关文章

React全家桶

React全家桶入门Demo http://react-china.org/t/react-demo/22800 最具性价比的一套就看react_home吧,从react出来就有的开源项目,react脚手架 https://github.com/aiyuekuang/react_home...

React之Antd组件<Input />属性defaultValue问题记录。

需求描述:   开发中遇到一个需求,表格需要修改每个数据(有<Input />, <Select />, <Radio />)和动态新增或删除一行,想到的办法是将表格数组数据存在state中,然后在渲染的时候把每个数据都放在组件中。如图:  出现问题:   不管点击第几行删除,页面显示出来的都是删除最后一行,但是使用c...

从零开始的野路子React/Node(7)将Swagger(OpenAPI)运用于后端API

之前公司做项目是用过swagger来配置python模型的API,感觉非常好用。swagger可以提供request, response甚至error的验证机制,十分便利。node当然也可以用啦。 我们需要使用的库主要是swagger-ui-express,它将提供swagger的相关功能以及一个UI,方便查看和调试。 1、初始设定 老规矩,我们还是通过e...

解决vscode开发react项目没有代码提示问题

1.安装插件 在插件库搜索:Reactjs code snippets,进行安装  2.禁用自动类型获取 打开设置,在搜索栏输入:@tag:usesOnlineServices,找到TypeScript:Disable Automatic Type Acquistion,将其禁用  3.解决JSX中tab没有自动补全 在JSX中HTML标签按tab键没...

umijs 开发优化和生产优化

.umirc.ts import { defineConfig } from 'umi'; import dev from './config/dev'; import prod from './config/prod'; console.log(process.env.NODE_ENV); const envConfig = 'developmen...

npm install -g create-react-app MacOS 报错解决

macOS 安装create-react-app报错解决: sudo npm uninstall -g create-react-app //删除之前对镜像 npm config set registry https://registry.npm.taobao.org // 安装还是不成功直接切换成淘宝镜像安装 npm config get regist...