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