React 组件性能优化

目录

扩展学习资料

React组件性能探寻【性能分析工具】

[React Profiler API](#React Profiler API)

[React Devtools](#React Devtools)

React组件性能优化

PureComponent

memo

自定义事件销毁

[Web Workers API](#Web Workers API)


扩展学习资料

|--------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| React Profiler 博客 | https://reactjs.org/blog/2018/09/10/introducing-the-react-profiler.html | 英文 |
| 理解火焰图 | Flame Graphs | |
| React Profiler API | https://reactjs.org/docs/profiler.html#gatsby-focus-wrapper | |
| React 优化手段 | https://www.codementor.io/blog/react-optimization-5wiwjnf9hj | |

React组件性能探寻【性能分析工具】

web性能整体分析工具

Reacr Devtools

依赖条件(最低要求)

  • React v16.5.0+(开发者模式)
  • React Developer Tools v3.3.2+

React Profiler API

不推荐,因为会产生额外的开销

javascript 复制代码
// 1.Profiler在'react'包中。
// onRender回调函数返回一系列信息。
export default function App(): ReactElement {
    const OnRender: (...params: any)=>void=(...params)=>{
        console.log(params)    
        params = {
            id, // 发生提交的 Profiler 树的 "id"
            phase, // "mount" (如果组件树刚加载) 或者 "update" (如果它重渲染了)之一
            actualDuration, // 本次更新 committed 花费的渲染时间
            baseDuration, // 估计不使用 memoization 的情况下渲染整棵子树需要的时间
            startTime, // 本次更新中 React 开始渲染的时间
            commitTime, // 本次更新中 React committed 的时间
            interactions // 属于本次更新的 interactions 的集合
        }
    }
    function onRenderCallback(
      
    ) {
      // 合计或记录渲染时间。。。
    }
    return (
        <Profiler id="router" onRender={onRenderCallback}>
        	<BrowserRouter>
         		<Route path="/" component={Home} />
        	</BrowserRouter>
        </Profiler>    
    )
}

React Devtools

javascript 复制代码
// 追踪用户行为
// 安装schedule包,yarn add schedule
// 在需要追踪的地方嵌入代码
import { unstable_track as track } from "schedule/track"
export default class Home extends Component {
    handleSubmit = e => {
        const text = e.target.value.trim()
        if (e.which === 13) {
            track("Add Tode", performance.now(), () => {
            	this.props.onSave(text)
             	if(this.props.newTode) {
                  this.setState({text:})              
              }                
            })        
        }    
    }
}

React组件性能优化

PureComponent

  • Class组件优化工具;
  • 实质是在shouldComponentUpdate方法中进行浅比较

memo

  • 函数组件优化的工具;
  • 是一个高阶函数,在其内部进行类似shouldComponentUpdate的比较;
  • 可以指定比较函数。

自定义事件销毁

  • 原生事件销毁->通常在ComponentDidMount中注册一些原生事件(如scroll,resize)
  • 定时器类销毁->开发中常见的定时器类操作

需在合适的位置(componentWillUnmount)进行销毁,否则易造成内存溢出

Web Workers API

  • Web Workers 使用后,Web应用程序可以:
    • 在独立于主线程的后台线程中运行一个脚本;
    • 在独立线程中执行费时的处理任务,避免一些耗时的任务阻断用户体验。
  • 通信机制 Web Workers执行完耗时任务后与主线程的通信--postMessage

不能操作DOM

相关推荐
刘联其29 分钟前
.net也可以用Electron开发跨平台的桌面程序了
前端·javascript·electron
韩曙亮29 分钟前
【jQuery】jQuery 选择器 ④ ( jQuery 筛选方法 | 方法分类场景 - 向下找后代、向上找祖先、同级找兄弟、范围限定查找 )
前端·javascript·jquery·jquery筛选方法
前端 贾公子30 分钟前
Node.js 如何处理 ES6 模块
前端·node.js·es6
pas13635 分钟前
42-mini-vue 实现 transform 功能
前端·javascript·vue.js
esmap1 小时前
OpenClaw与ESMAP AOA定位系统融合技术分析
前端·人工智能·计算机视觉·3d·ai·js
2501_921930831 小时前
基础入门 React Native 鸿蒙跨平台开发:Video 全屏播放与画中画 鸿蒙实战
react native·react.js·harmonyos
毕设源码-钟学长1 小时前
【开题答辩全过程】以 基于node.js vue的点餐系统的设计与实现为例,包含答辩的问题和答案
前端·vue.js·node.js
小白路过1 小时前
记录vue-cli-service serve启动本地服务卡住问题
前端·javascript·vue.js
2501_921930831 小时前
基础入门 React Native 鸿蒙跨平台开发:react-native-switch 开关适配
react native·react.js·harmonyos
We་ct1 小时前
LeetCode 1. 两数之和:两种高效解法(双指针 + Map)
前端·算法·leetcode·typescript·哈希算法