react 之 performance、Reconciliation

performance:

1、使用 production 模式;

2、插件:

uglify-js-brunch :minify js 文件

envify:确认配置了正确环境

uglifyify:minify code

UglifyJS: a JavaScript parser, minifier, compressor and beautifier toolkit.

3、开发环境性能调试:

(1)Chrome Performance

(2)DevTools Profiler

4、渲染超长列表使用:react-window

5、avoid reconcilation:使用 PureComponent、shouldComponentUpdate(which is triggered before the re-rendering process starts),但是这两种方案只是进行了浅比较,而对于复杂的数据结构的变化则会出问题。

解决办法:不要改变 state、props 的数据(就是深拷贝数据),使用 Immutable data:(1)...扩展语法、(2)Object.assign、(3)Immutable.js。immutable 结构数据可以很方便跟踪对象的变化。

Reconciliation:

what made in React’s “diffing” algorithm

动机:render() 可看做是在创建一个 react 组件树,组件更新的算法复杂度为 O(n3),n 为组件数。基于这两种前提下:(1)不同类型的两个元素会生成不同的 tree;(2)开发者可通过为元素增加 key 属性来避免不必要的更新。(这两种假设适用于大多数场景)算法复杂可降为 O(n)。

diff 算法:

(1)元素类型不一致,整个元素都会改变

(2)元素类型一致,则只改变属性

(3)然后迭代比较子元素

加唯一 key 值来防止不需要更新元素进行不必要的更新。

tradeoffs:

 reconciliation algorithm is an implementation detail。

Portals:

渲染一个 child 到一个特定的 DOM 节点中,如下代码,child 会属于 container 的子元素,而不属于引用下面代码的组件(引用组件)。

使用:

render(){

    return ReactDOM.createPortal(child, container);

}

场景:悬浮卡片、dialogs 等。

事件冒泡:引用组件可监听 child 中时间。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 3. JSX JSX是对JavaScript语言的一个扩展语法, 用于生产React“元素”,建议在描述UI的时候...
    pixels阅读 2,908评论 0 24
  • 官网地址https://facebook.github.io/react/docs/hello-world.htm...
    pixels阅读 718评论 0 6
  • 原教程内容详见精益 React 学习指南,这只是我在学习过程中的一些阅读笔记,个人觉得该教程讲解深入浅出,比目前大...
    leonaxiong阅读 2,862评论 1 18
  • 前端开发面试题 面试题目: 根据你的等级和职位的变化,入门级到专家级,广度和深度都会有所增加。 题目类型: 理论知...
    怡宝丶阅读 2,615评论 0 7
  • 继上次我发了一个比较难看的包以后,昨天又做了一个,但我觉得好方便,所以分享一下。 这个包包是个小手机斜跨包,中间有...
    孤芳自赏手作阅读 379评论 0 1