React -- 组件生命周期

本文详细介绍了React组件的生命周期,包括挂载、渲染和卸载三个阶段。解析了组件挂载过程中的componentWillMount与componentDidMount方法的区别,以及组件卸载时的componentWillUnmount方法的应用场景。同时探讨了组件在接收到新数据时的更新过程,涵盖了shouldComponentUpdate、componentWillUpdate、componentDidUpdate等关键方法的作用及注意事项。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

React的生命周期分为挂载、渲染和卸载三个阶段。

这三个阶段分为两类:
1、组件在挂载或卸载时
2、组件接受新的数据时,即组件更新渲染时

卸载和挂载

1、组件的挂载

class App extends Component { 
    static propTypes = {
        // ...
    };
    static defaultProps = { 
        // ...
    };
    constructor(props) { 
        super(props);
        this.state = { 
            // ...
        }; 
    }
    componentWillMount() { 
        // ...
    }
    componentDidMount() {
         // ...
    }
    render() {
        return <div>This is a demo.</div>;
    } 
}

propTypes和defaultProps代表props类型检查和默认类型,并且被声明为静态属性,我们可以使用APP.propTypes这样的方式访问它们。

声明周期方法componentWillMount将在render方法前执行,而componentDidMount则会在render方法后执行。

如果我们在componentWillMount中执行setState: 组件会更新state,但是只渲染一次。因此,不必要在componentWillMount中再次执行setState, 直接在constructor中将state设置稳妥即可。

但是如果在componentDidMount中执行了setState,组件就会再次更新,这样,初始化的过程中组件就渲染了两次,这样效率不高,不是推荐的做法。

2、组件的卸载

组件的卸载很简单,涉及的生命周期方法为componentWillUnmount。在这个方法中,通常执行一些清理方法,例如事件回收和清除定时器等。

数据的更新过程

更新过程指的是父组件向下传递props活着组件自身执行setState方法时发生的一系列更新动作。

如果组件自身的state更新了,那么就会依次执行shouldComponentUpdate、componentWillUpdate、render、componentDidUpdate。

shouldComponentUpdate(nextProps, nextState) { 
    // return true;
}

shouldComponentUpdate:它接收需要更新的props和state,开发者可以根据需要,判断是否需要更新,如果不需要更新,将方法返回false,组件将不会再向下执行生命周期的方法。

shouldComponentUpdate的本质是用来进行正确的组件渲染。当父节点的props改变的时候,在理想的情况下, 应该只渲染某DOM树上某一条链路上的节点。而在默认情况下,React会渲染此父节点下所有的跟节点(shouldComponentUpdate默认返回true),因此,利用shouldComponentUpdate方法砍去没必要的渲染,是性能优化的手段之一。

另外,关于componentWillUpdate和componentDidUpdate,前者提供需要更新的props和state,后者提供更新前的props和state。需要注意的是,不能在componentWillUpdate中执行setState。

如果组件是由于父组件更新了它的props而更新的,那么在shouldComponentUpdate方法之前,会先执行componentWillReceiveProps方法。此方法可以作为React在props传入后,渲染之前setState的机会,在此方法中调用setState是不会二次渲染的。

整体流程图:
React生命周期流程图

使用ES6 class与creatClass的异同:
使用ES6 class与creatClass的异同

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值