本文翻译自 5 Recommended Tools for Optimizing Performance in ReactJS,作者 Chidume Nnamdi,有较大的删改。
可以前往 codesandbox.io/s/react-pro… 在线编辑效果。
Profiler
是 React 中的一个组件,由 B. Vaughn 开发,它可以测量 React 应用渲染的频率和渲染所花费的时间资源。Profiler
提供一个函数属性 onRender
,当组件 mount 或者 update 的时候,这个函数会接受到一些时间指标。用这些时间指标你就可以发现效率低下的代码了。
import React, { Profiler } from 'react'; ... <Profiler id="Counter1" onRender={this.callback1(this)}> <Counter1 /> </Profiler> 复制代码
id
用来标识对应的 Profiler 组件,onRender
函数会在组件 mount 或者 update 的时候执行,它的参数结构如下:
function onRenderCallback( id, phase, actualDuration, baseDuration, startTime, commitTime, ) { console.log('onRenderCallback', { id, phase, actualDuration, baseDuration, startTime, commitTime, }) } 复制代码
id
组件 id;phase
执行阶段,mount 或者 update;actualDuration
Profiler 和子组件渲染当前的更新所花费的时间,这个值在首次 mount 的时候比 update 阶段的值大;baseDuration
子组件最近一次渲染所持续的时长startTime
开始渲染当前的更新的时间戳commitTime
React 提交当前更新的时间戳这些数据可以帮助我们分析组件运行的效率,找到性能瓶颈。
React Developer tools 是 React 官方团队发布的一个浏览器插件,功能十分强大。我要介绍的是 Highlight Update 这个功能。这个工具用来检测组件重复渲染非常有效。他可以用不同的颜色来标识组件的边框,颜色越黄表示这个组件重复渲染的次数越多。
如果你有一个组件树像下面这样:
如果 Main 组件重复渲染了,那么封装 Counter 和 Count 组件的边界就会出现一个边框表示重复渲染。
我们激活这个特性之后,在 ReactJS 官网开启关闭右侧的菜单,会出现边框提示:
如何激活这个特性呢?找到调试工具的 Components 一栏,点击右上角的小齿轮,再选中弹窗中的 Highlight updates when components render.
边框的类型取决于重复渲染的程度,重复渲染越多,颜色越深。
| 绿色 - 低频次更新 | 蓝色 - 一般频次更新 v 红色 - 高频次更新 复制代码
通过使用这个工具,我们可以通过边框颜色来轻易找到有性能问题的组件,并对它做针对性的优化。
github.com/welldone-so…,这个工具是由 Welldone Software 开发的,用来对组件重复渲染给出反馈。
它会对组件的 props 做 diff,如果组件重新渲染了,但是 props 并没改变,它会在命令行提醒你 props 并没有变化。
重复渲染在小型应用中影响可能不大,但是在大型项目中将肯定会有影响。
这个工具嵌入到了 React 组件的生命周期中,所以他能在组件重新渲染时比对 props 是否变化。
使用方法很简单,先安装
npm install @welldone-software/why-did-you-render --save 复制代码
然后注册一次:
whyDidYouRender(React, { trackAllPureComponents: true }); 复制代码
然后对 class component:
class Counter extends React.Component { static whyDidYouRender = true; render() { //... } } 复制代码
对函数组件:
function Counter() { return( // ... ) } Counter.whyDidYouRender = true; 复制代码
下面是一个完整的例子,每次 setState
时候,style={{ width: "100%" }}
都是一个新的值,所以会触发比对。
import React from "react"; import "./styles.css"; const whyDidYouRender = require("@welldone-software/why-did-you-render"); whyDidYouRender(React, { trackAllPureComponents: true }); export default class App extends React.Component { constructor() { super(); this.state = { count: 1 }; } render() { return ( <div className="App"> <button onClick={() => this.setState({ count: this.state.count + 1 })}> add </button> <p>{this.state.count}</p> <Comp style={{ width: "100%" }} /> </div> ); } } function Comp(props) { return <div>100</div>; } Comp.whyDidYouRender = true; 复制代码
前往 Code SandBox 测试 codesandbox.io/s/distracte…。
这个工具是 Chrome 自带的调试工具,在 Performance 一栏中。
它可以非常有效地查看严重重复渲染的组件,它也可以很方便地查看 UI 不必要的更新及其出现的频次。
在使用工具之前,先以开发模式把你的 React app 启动起来。
然后,打开开发者工具,切换到 Performance 面板。
点击中间的圆点或者用快捷键 command + e,开发者工具就开始录制了,然后你可以在你的应用中做一些交互动作。
建议录制时间在 20 秒以上,时间到了之后,点击中间的 stop,或者左上角红点。
然后我们就可以看到时间线了。
我们可以滑动选择一片区域,然后通过 W 放大或者通过 S 缩小。选中一片区域,通过 W 键一直放大。
每个橙色的条代表一个执行过程,在这个条中你可以看到组件名、组件执行的阶段、以及执行时间。在上面这张图片中,App 的执行阶段是 update 阶段,这表示 App 组件这段时间是在执行更新操作,执行所耗费的时间是 1.71 ms。
组件每次渲染的时候一个新的黄条就会生成,如果一个组件多次渲染,通过这个 Timings 图表可以让你更容易追因。每个黄条的长度表示组件的执行时间,黄条越长,执行时间也越长。你可以使用这个工具来诊断页面。
如果你觉得文章不错,请点上一个赞👍,如果你有疑惑,可以在评论区提问,创作不易,您的点赞和评论是对我最大的鼓励~~
欢迎关注公众号 云影sky,分享的不仅仅是技术,还有成长~~
神策数据(sensorsdata.cn) 招人啦~~
公司在北京、上海、武汉、成都、合肥、深圳招人中,待遇优厚~
零食、肥宅快乐水、免费午餐晚餐、晚上下班免费坐车...
神策数据(Sensors Data)隶属于神策网络科技 (北京) 有限公司,是专业的大数据分析平台服务提供商,致力于帮助客户实现数据驱动。公司围绕用户级大数据分析和管理需求,推出神策分析、神策智能运营、神策智能推荐、神策用户画像、神策客景等产品。
目前,神策已积累中国银联、中国电信、小米、中邮消费金融、海通证券、广发证券、东方证券、中原银行、百信银行、中青旅、平安寿险、四川航空、翼支付、好未来、VIPKID、华润、有赞、百姓网、货拉拉、闪送、驴妈妈、Keep、36氪、拉勾、VUE、春雨医生、聚美优品、捞月狗、纷享销客、妈妈帮等 1000 余家付费企业用户的服务和客户成功经验,为客户全面提供指标梳理、数据模型搭建等专业的咨询、实施和技术支持服务。
创始人、CEO 桑文锋:在百度任职 8 年,构建了百度用户日志大数据平台。历任软件工程师、高级软件工程师、项目经理、高级项目经理、技术经理,2015 年离职创建神策数据,针对企业级用户推出用户行为分析产品神策分析,帮助企业实现数据驱动。
联合创始⼈、CTO 曹犟:清华⼤学计算机硕⼠,2008 年⾄ 2014 年就职于百度⼤数据部,担任百度⽤户数据仓库(BUDW)技术负责⼈,2015 年 4 ⽉成为神策数据联合创始⼈并担任神策数据 CTO 职务。
联合创始⼈、COO 刘耀洲:中国地质⼤学计算机应⽤技术硕⼠。曾供职于新浪、阿⾥巴巴、百度等公司,2015 年 4 ⽉离开百度,作为联合创始⼈创⽴神策数据并任 COO。
联合创始⼈、技术 VP 付⼒⼒:毕业于北京理⼯⼤学软件⼯程专业,2008 年⾄ 2013 年期间历任百度新产品研发部、⽹页搜索部、基础架构部⼯程师。现任神策数据联合创始⼈及技术VP。
红杉资本、华平投资、DCM 中国、襄禾资本持续跟投,公司技术有挑战,待遇也非常好,诚邀各位大牛加入~~
工作职责:
我们的挑战:
对工程师的要求:
工作职责:
职位要求:
工作职责:
岗位要求:
工作职责:
岗位要求:
岗位职责:
任职要求:
工作职责:
岗位要求:
ios sdk
android sdk
web js sdk
职位描述:
职位要求:
工作职责:
职位要求:
工作职责:
岗位要求:
工作职责:
岗位要求:
工作职责:
岗位要求:
工作职责:
岗位要求:
把你的简历砸过来吧~~
Sensors Data - 给客户带来价值
简历投递:liu3248184446@outlook.com