加入有如下代码;
setTimeout(()=>{ <A data = {data}></A> },1000)这里每隔1 秒 就刷新一次,这个时候 A 组件会每次重复diff 算法,看是否该重新渲染,然后走render 方法
这样效率太低,我们的设想就是,只要 data 数据不变,我们就不会渲染,这样会节省很大的成本
所以这就有了纯组件的概念:一种是class 的方式(通过继承实现)
一种是 函数的方式,我们通过 函数包装的方式实现
PureComponent 定制了shouldComponentUpdate后的Component
class Comp extends React.PureComponentReact.memo React 16.6.0 使用 React.memo 让函数式的组件也有PureComponent的功能
const Joke = React.memo(() => (<div>{this.props.value || 'loading...' }</div>)只要通过这个两种方式包装后就会实现 显示组件的属性值的浅比较,这个时候
我们需要注意点,注意点,注意点::
就是给纯组件传递值的时候,一定要是 值传递!
data= { a:100, b:88 }// 这种方式不行,传递的是引用,指针,不是值传递 <A data= {data}></A>
应当如下方式传递: <A {...data }></A> 这种方式相当于 <A a=100 b=88></A>这种写法见到了就行了!