React 生命周期函数的使用

import React from 'react';
import ReactDOM from 'react-dom';
import 'bootstrap/dist/css/bootstrap.css';

// import PropTypes from 'prop-types';
function computed() {
    return new Promise(res => {
        setTimeout(() => {
            res(2)
        }, 5000)
    })
}

class A extends React.Component {
    // static defaultProps = {m: 1, title: 444}//将传递进来的属性值设置默认值之后,才向下执行
    constructor() {
        super();
        console.log('1-CONSTRUCTOR');
        this.state = {n: 0, m: 0}
    }

    async componentWillMount() {
        console.log('2 :第一次渲染之前', this.refs.HH)
        let n = await computed();
        this.setState({//改变状态
            n: n
        })
    }

    componentDidMount() {
        console.log('4 :第一次渲染之后', this.refs.HH);
        //真是项目中一般第一次组建渲染我们绑定的都是默认数据,第二次绑定的才是从服务器获取的
        //数据
        // setInterval(() => {
        //     this.setState({//改变状态
        //         n: this.state.n + 1
        //     })
        // }, 10000)
        /*
        * 真是项目中在这个阶段一般做如下操作
        * 1.控制状态信息更改的操作
        * 2.从服务器获取数据,然后修改状态信息完成数据绑定
        * */
    }

    componentWillReceiveProps(nextProps, nextContext) {
        console.log('组建属性改变',this.props.n, nextContext.n);
    }

    shouldComponentUpdate(nextProps, nextState) {
        /*
        *nextProps:最新修改的属性信息
        *nextState:最新修改的状态信息
        * 在这个钩子函数中我们获取的STATE不是最新你修改的二十上一次的STATE值
        *
        * */
        console.log("this.state.n", this.state.n)
        console.log("nextProps", nextProps);//{m: 1,title:444}
        console.log("nextState", nextState);//{n: 5, m: 0}
        console.log('5 :是否允许下更新')//函数返回true就是允许更新否者不可以更新
        if (nextState.n < 3) {
            return true;
        }
        return true;
    }

    componentWillUpdate(nextProps, nextState) {
        /*
        * 这里获取的状态是更新之前的(和should相同也有两个参数存储最新的参数)
        * */
        console.log('6 :重新渲染之前')//函数返回true就是允许否者不可以
    }

    componentDidUpdate(ev) {
        console.log('8 :组建更新之后')//函数返回true就是允许否者不可以
    }

    render() {
        console.log('3 :render渲染')
        return <div ref='HH'>
            <h1>{this.props.n}</h1>
            <h1>{this.state.n}</h1>
        </div>
    }
}

class B extends React.Component {
    constructor() {
        super();
        this.state = {n: 1}
    }

    componentDidMount() {
        setTimeout(() => {
            this.setState({
                n: 7
            })
        }, 7000)
    }

    render() {
        return <div>
            <A n={this.state.n}></A>
        </div>
    }
}

let root = document.getElementById("root")
ReactDOM.render(<B title="5555"></B>, root)



  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值