成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

推薦幾個 React 性能優化工具

開發 前端
Profiler 是 React 中的一個組件,由 B. Vaughn 開發,它可以測量 React 應用渲染的頻率和渲染所花費的時間資源。Profiler 提供一個函數屬性 onRender,當組件 mount 或者 update 的時候,這個函數會接受到一些時間指標。

 Profiler

 

推薦幾個 React 性能優化工具

 

Code SandBox

可以前往

https://codesandbox.io/s/react-profiler-example-o75nc?fontsize=14&hidenavigation=1&theme=dark 在線編輯效果。

Profiler 是 React 中的一個組件,由 B. Vaughn 開發,它可以測量 React 應用渲染的頻率和渲染所花費的時間資源。Profiler 提供一個函數屬性 onRender,當組件 mount 或者 update 的時候,這個函數會接受到一些時間指標。用這些時間指標你就可以發現效率低下的代碼了。

 

  1. import React, { Profiler } from 'react'
  2.  
  3. ... 
  4. <Profiler id="Counter1" onRender={this.callback1(this)}> 
  5.   <Counter1 /> 
  6. </Profiler> 

id 用來標識對應的 Profiler 組件,onRender 函數會在組件 mount 或者 update 的時候執行,它的參數結構如下:

 

  1. function onRenderCallback(  id, 
  2.   phase, 
  3.   actualDuration,  
  4.   baseDuration, 
  5.   startTime, 
  6.   commitTime,) { 
  7.   console.log('onRenderCallback', { 
  8.     id, 
  9.     phase, 
  10.     actualDuration,  
  11.     baseDuration, 
  12.     startTime, 
  13.     commitTime, 
  14.   }) 
  • id 組件 id;
  • phase 執行階段,mount 或者 update;
  • actualDuration Profiler 和子組件渲染當前的更新所花費的時間,這個值在首次 mount 的時候比 update 階段的值大;
  • baseDuration 子組件最近一次渲染所持續的時長
  • startTime 開始渲染當前的更新的時間戳
  • commitTime React 提交當前更新的時間戳

這些數據可以幫助我們分析組件運行的效率,找到性能瓶頸。

React Developer tools

 

推薦幾個 React 性能優化工具

 

React Developer tools 是 React 官方團隊發布的一個瀏覽器插件,功能十分強大。我要介紹的是 Highlight Update 這個功能。這個工具用來檢測組件重復渲染非常有效。他可以用不同的顏色來標識組件的邊框,顏色越黃表示這個組件重復渲染的次數越多。

如果你有一個組件樹像下面這樣:

 

推薦幾個 React 性能優化工具

 

如果 Main 組件重復渲染了,那么封裝 Counter 和 Count 組件的邊界就會出現一個邊框表示重復渲染。

我們激活這個特性之后,在 ReactJS 官網開啟關閉右側的菜單,會出現邊框提示:

 

推薦幾個 React 性能優化工具

 

如何激活這個特性呢?找到調試工具的 Components 一欄,點擊右上角的小齒輪,再選中彈窗中的 Highlight updates when components render.

 

推薦幾個 React 性能優化工具

 

邊框的類型取決于重復渲染的程度,重復渲染越多,顏色越深。

 

  1. |    綠色 - 低頻次更新 
  2. |    藍色 - 一般頻次更新 
  3. v    紅色 - 高頻次更新 

通過使用這個工具,我們可以通過邊框顏色來輕易找到有性能問題的組件,并對它做針對性的優化。

why-did-you-render

 

 

https://github.com/welldone-software/why-did-you-render,這個工具是由 Welldone Software 開發的,用來對組件重復渲染給出反饋。

它會對組件的 props 做 diff,如果組件重新渲染了,但是 props 并沒改變,它會在命令行提醒你 props 并沒有變化。

重復渲染在小型應用中影響可能不大,但是在大型項目中將肯定會有影響。

這個工具嵌入到了 React 組件的生命周期中,所以他能在組件重新渲染時比對 props 是否變化。

使用方法很簡單,先安裝

 

  1. npm install @welldone-software/why-did-you-render --save 

然后注冊一次:

 

  1. whyDidYouRender(React, { 
  2.   trackAllPureComponents: true 
  3. }); 

然后對 class component:

 

  1. class Counter extends React.Component { 
  2.   static whyDidYouRender = true
  3.   render() { 
  4.    //... 
  5.   } 

對函數組件:

 

  1. function Counter() { 
  2.   return
  3.    // ... 
  4.   ) 
  5. Counter.whyDidYouRender = true

下面是一個完整的例子,每次 setState 時候,style={{ width: "100%" }} 都是一個新的值,所以會觸發比對。

  1. import React from "react"
  2. import "./styles.css"
  3. const whyDidYouRender = require("@welldone-software/why-did-you-render"); 
  4. whyDidYouRender(React, { 
  5.   trackAllPureComponents: true 
  6. }); 
  7. export default class App extends React.Component { 
  8.   constructor() { 
  9.     super(); 
  10.     this.state = { 
  11.       count: 1 
  12.     }; 
  13.   } 
  14.   render() { 
  15.     return ( 
  16.       <div className="App"
  17.         <button onClick={() => this.setState({ count: this.state.count + 1 })}> 
  18.           add 
  19.         </button> 
  20.         <p>{this.state.count}</p> 
  21.         <Comp style={{ width: "100%" }} /> 
  22.       </div> 
  23.     ); 
  24.   } 
  25. function Comp(props) { 
  26.   return <div>100</div>; 
  27. Comp.whyDidYouRender = true

前往 Code SandBox 測試

https://codesandbox.io/s/distracted-architecture-t9ih2?file=/src/App.js。

Performance timeline (Browser profiling)

這個工具是 Chrome 自帶的調試工具,在 Performance 一欄中。

它可以非常有效地查看嚴重重復渲染的組件,它也可以很方便地查看 UI 不必要的更新及其出現的頻次。

在使用工具之前,先以開發模式把你的 React app 啟動起來。

然后,打開開發者工具,切換到 Performance 面板。

 

推薦幾個 React 性能優化工具

 

點擊中間的圓點或者用快捷鍵 command + e,開發者工具就開始錄制了,然后你可以在你的應用中做一些交互動作。

建議錄制時間在 20 秒以上,時間到了之后,點擊中間的 stop,或者左上角紅點。

 

推薦幾個 React 性能優化工具

 

然后我們就可以看到時間線了。

 

推薦幾個 React 性能優化工具

 

我們可以滑動選擇一片區域,然后通過 W 放大或者通過 S 縮小。選中一片區域,通過 W 鍵一直放大。

 

推薦幾個 React 性能優化工具

 

每個橙色的條代表一個執行過程,在這個條中你可以看到組件名、組件執行的階段、以及執行時間。在上面這張圖片中,App 的執行階段是 update 階段,這表示 App 組件這段時間是在執行更新操作,執行所耗費的時間是 1.71 ms。

組件每次渲染的時候一個新的黃條就會生成,如果一個組件多次渲染,通過這個 Timings 圖表可以讓你更容易追因。每個黃條的長度表示組件的執行時間,黃條越長,執行時間也越長。你可以使用這個工具來診斷頁面。

 

責任編輯:華軒 來源: 今日頭條
相關推薦

2021-09-13 10:23:52

工具ProfilerSQL

2011-09-09 15:01:39

Win7優化工具

2021-08-27 14:26:06

開發技能React

2021-06-17 08:59:45

React前端優化

2013-10-16 14:18:02

工具圖像處理

2019-02-25 07:07:38

技巧React 優化

2021-08-10 09:38:50

elementaryLinux

2022-08-03 09:11:31

React性能優化

2016-12-19 10:00:00

React性能優化

2023-11-01 17:57:56

React應用程序性能

2021-04-11 09:51:25

Redis可視化工具

2010-08-09 09:14:37

Flex代碼格式化

2012-05-15 09:00:12

AppSEOASO優化工具

2022-07-22 14:45:46

SDKVolcRTC內存優化

2019-02-26 09:14:02

SSD狀態監控

2014-09-12 10:42:40

Linux監控

2021-05-10 08:08:25

工具LightHouse性能優化

2021-05-12 06:02:56

性能優化工具WebPageTest

2019-02-26 15:17:15

工具性能數據

2018-01-31 18:32:06

數據庫Oracle優化工具
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 免费观看的av | 亚洲国产精品久久 | 午夜丰满少妇一级毛片 | 国产一级黄色网 | 国产精品视频在线播放 | 中文字幕一区二区三区精彩视频 | 亚洲美女网站 | 久久国产精品久久国产精品 | 视频国产一区 | 不用播放器看的av | 九色视频网站 | 精品国产18久久久久久二百 | 91久久国产综合久久 | 久久精品视频网站 | 亚洲一区毛片 | 亚洲国产欧美日韩 | 日干夜干 | 日韩一区二区久久 | 欧美女优在线观看 | 综合色久| 二区av| 超碰国产在线 | 在线观看视频福利 | 91精品国产一区二区三区 | 精品国产区 | 亚洲精品久久久一区二区三区 | 成人免费观看男女羞羞视频 | 一区二区三区免费 | 欧美三区| 中文字幕在线免费视频 | 久久精品亚洲 | av一区二区三区四区 | 中文字幕在线观看www | 亚洲国产精品一区二区第一页 | 国产成人精品久久二区二区 | 精品免费国产一区二区三区四区 | 日韩网站在线 | 日韩av一区在线观看 | 麻豆精品国产免费 | www.99热这里只有精品 | 国产欧美三区 |