React性能优化的手段有哪些?

主要手段是通过shouldComponentUpdate、PureComponent、React.memo,

除此之外, 常见性能优化常见的手段有如下:

  • 避免使用内联函数

  • 使用 React Fragments 避免额外标记

  • 使用 Immutable

  • 给子组件中设置一个唯一的key

  • 将props设置为数组或者是对象

懒加载组件

事件绑定:将函数的绑定移动到构造函数中,可以避免每次绑定事件

服务端渲染

避免使用内联函数

如果我们使用内联函数,则每次调用render函数时都会创建一个新的函数实例,如下:

import React from"react";exportdefaultclassInlineFunctionComponentextendsReact.Component{render(){return(<div>
        <h1>Welcome Guest</h1>
        <inputtype="button"onClick={(e)=>{this.setState({inputValue: e.target.value})}}value="Click For Inline Function"/>
      </div>)}}

我们应该在组件内部创建一个函数,并将事件绑定到该函数本身。这样每次调用 render 时就不会创建单独的函数实例,如下:

import React from"react";exportdefaultclassInlineFunctionComponentextendsReact.Component{setNewStateData=(event)=>{this.setState({
      inputValue: e.target.value
    })}render(){return(<div>
        <h1>Welcome Guest</h1>
        <inputtype="button"onClick={this.setNewStateData}value="Click For Inline Function"/>
      </div>)}}
使用 React Fragments 避免额外标记

用户创建新组件时,每个组件应具有单个父标签。父级不能有两个标签,所以顶部要有一个公共标签,所以我们经常在组件顶部添加额外标签div

这个额外标签除了充当父标签之外,并没有其他作用,这时候则可以使用fragement

其不会向组件引入任何额外标记,但它可以作为父级标签的作用,如下所示:

exportdefaultclassNestedRoutingComponentextendsReact.Component{render(){return(<>
                <h1>This is the Header Component</h1>
                <h2>Welcome To Demo Page</h2>
            </>)}}

事件绑定方式

从性能方面考虑,在render方法中使用bind和render方法中使用箭头函数这两种形式在每次组件render的时候都会生成新的方法实例,性能欠缺

而constructor中bind事件与定义阶段使用箭头函数绑定这两种形式只会生成一个方法实例,性能方面会有所改善

使用 Immutable

我们了解到使用 Immutable可以给 React 应用带来性能的优化,主要体现在减少渲染的次数

在做react性能优化的时候,为了避免重复渲染,我们会在shouldComponentUpdate()中做对比,当返回true执行render方法

Immutable通过is方法则可以完成对比,而无需像一样通过深度比较的方式比较

懒加载组件

从工程方面考虑,webpack存在代码拆分能力,可以为应用创建多个包,并在运行时动态加载,减少初始包的大小

而在react中使用到了Suspense和 lazy组件实现代码拆分功能,基本使用如下:

const johanComponent = React.lazy(()=>import(/* webpackChunkName: "johanComponent" */'./myAwesome.component'));exportconstjohanAsyncComponent=props=>(<React.Suspensefallback={<Spinner/>}>
    <johanComponent{...props}/>
  </React.Suspense>);

服务端渲染

采用服务端渲染端方式,可以使用户更快的看到渲染完成的页面

服务端渲染,需要起一个node服务,可以使用express、koa等,调用react的renderToString方法,将根组件渲染成字符串,再输出到响应中

例如:

import{ renderToString }from"react-dom/server";import MyPage from"./MyPage";
app.get("/",(req, res)=>{
  res.write("<!DOCTYPE html><html><head><title>My Page</title></head><body>");
  res.write("<div id='content'>");  
  res.write(renderToString(<MyPage/>));
  res.write("</div></body></html>");
  res.end();});

客户端使用render方法来生成HTML

import ReactDOM from'react-dom';import MyPage from"./MyPage";
ReactDOM.render(<MyPage/>, document.getElementById('app'));
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值