React生命周期函数

说来惭愧,准大四计算机专业学生党第一次写技术博客。

以前学东西没有记录的习惯总是容易忘记。

最近在看老师的教程学习React框架,想写点东西记录一下学习的过程。

若写的不好,各位大佬见谅了,欢迎指正。

 

什么是生命周期函数?

生命周期函数就是组件某一时刻会自动执行的函数。

React生命函数如下图所示分为四个部分

Initialzation:    初始化

Mounting:       组件被挂载

Updation:       组件被更新

Unmounting:  组件被移除

 

接下来我会对每个生命周期函数函数写测试用例:

父组件内:

    //组件被挂载之前,自动执行
    componentWillMount(){
        console.log("componentWillMount");
    }
    //组件被挂载之后,自动执行
    componentDidMount(){
        console.log("componentDidMount");
    }
    //组件渲染到页面上的时候,自动执行
    render(){
            console.log("parent render");
    }
    //组件被更新前,自动执行
    //返回值为true组件可被更新
    //返回值为false组件不可被更新
    shouldComponentUpdate(){
        console.log("shouldComponentUpdate");
        return true;
    }
    //组件被更新前,自动执行,但在shouldComponentUpdate之后
    //如果shouldComponentUpdate为true,它才执行,否则不执行
    componentWillUpdate(){
        console.log("componentWillUpdate");
    }
    //组件更新完,自动执行
    componentDidUpdate(){
        console.log("componentDidUpdate");
    }

子组件内:

    //当一个组件从父组件接收参数时
    //如果这个组件第一次存在父组件中,不执行
    //如果这个组件之前已经存在父组件中,才会执行。
    componentWillReceiveProps(){
        console.log("child componentWillReceiveProps")
    }
    //当一个组件即将被从页面中剔除的时候,自动执行
    componentWillUnmount(){
        console.log("child componentWillUnmount")
    }

好,接下来根据我之前所写好的React组件测试代码来看一下结果。

第一次加载页面
输出input值

 

 

 

 

 

 

 

 

 

 

第一次提交子
第二次提交

 

 

 

 

 

 

 

 

 

 

 

移除

 

React中的生命周期函数指的是在组件的生命周期中会被自动调用的一些特定函数。以下是React的常见生命周期函数: 1. constructor(props): 组件创建时调用的函数,用于初始化状态和绑定方法。 2. static getDerivedStateFromProps(props, state): 组件创建和更新时调用的静态函数,在render之前调用。它接收props和state作为参数,返回一个对象来更新state,或者返回null。 3. render(): 渲染函数,用于返回组件的JSX结构。 4. componentDidMount(): 组件挂载后调用的函数,通常用于进行DOM操作、网络请求等副作用操作。 5. shouldComponentUpdate(nextProps, nextState): 组件更新前调用的函数,用于判断是否需要重新渲染组件。默认情况下,每次state或props更新都会重新渲染组件。 6. getSnapshotBeforeUpdate(prevProps, prevState): 组件更新前调用的函数,在render之后、组件DOM更新之前调用。它接收prevProps和prevState作为参数,返回一个值,将作为第三个参数传递给componentDidUpdate()函数。 7. componentDidUpdate(prevProps, prevState, snapshot): 组件更新后调用的函数,通常用于进行DOM操作、网络请求等副作用操作。 8. componentWillUnmount(): 组件卸载前调用的函数,用于清理定时器、取消网络请求等操作。 这些生命周期函数在组件的不同阶段会被自动调用,开发者可以在相应的生命周期函数中执行特定的操作,以实现组件的逻辑和交互效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值