一、React中Props与state的区别
1、数据来源不同
props
是由父组件传递给子组件的数据,可以认为是只读的,子组件不能直接修改props
的值。而state
是组件内部自己管理的数据,可以由组件自己修改。
2、数据类型
props
可以传递任何JavaScript类型的数据,包括基本数据类型、对象、数组等。而state
一般是对象类型。
3、生命周期
组件的props
可以在组件的生命周期中任意时刻被更新,因为它是由父组件传递给子组件的。而state
一般在constructor
中初始化,在组件的生命周期中被更新,但不能在生命周期外部直接修改。
4、作用范围
props
的作用范围是整个组件树,也就是所有子组件都可以使用父组件传递过来的props
。而state
的作用范围是组件内部,只有当前组件可以访问和修改。
5、优化性能
由于props
是只读的,当父组件重新渲染时,即使props
值没有发生改变,子组件也会重新渲染。而通过使用shouldComponentUpdate
等生命周期函数,可以避免不必要的子组件重复渲染。