react 简单优化设计-纯组件的优化

    技术2022-07-12  86

    加入有如下代码;

    setTimeout(()=>{ <A data = {data}></A> },1000)

    这里每隔1 秒 就刷新一次,这个时候 A 组件会每次重复diff 算法,看是否该重新渲染,然后走render 方法

    这样效率太低,我们的设想就是,只要 data 数据不变,我们就不会渲染,这样会节省很大的成本

    所以这就有了纯组件的概念:一种是class 的方式(通过继承实现)

    一种是 函数的方式,我们通过 函数包装的方式实现

    PureComponent 定制了shouldComponentUpdate后的Component

    class Comp extends React.PureComponent

    React.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>

    这种写法见到了就行了!

    Processed: 0.018, SQL: 9