React性能检测和优化

性能检测
安装检测工具 npm i react-addons-perf --save,然后在./app/index.jsx中写这段代码

    import Perf from "react-addons-perf"
    if(__DEV__){
        window.Perf = Perf
    }

如果报错:Perf is not defined 则删除上面代码第二行和第四行

运行程序,先在console里面打印Perf.start(),然后在进行若干操作,在运行Perf.stop(),然后再运行Perf.printWasted(),即可打印出浪费性能的组件列表,在项目开发中,要经常使用检测工具来看性能是否正常。

PureRenderMixin性能优化
安装工具:npm i react-addons-pure-render-mixin --save,然后在组件中引用

import React from "react"
import PureRednderMixin from "react-addons-pure-render-mixin"

export default class Index extends React.Component{
    constructor(props,context){
        super(props,context)
        this.shouldComponentUpdate = PureRenderMixin.shouldComponentUpdate.bind(this)
    }

}

React有一个生命周期函数叫做shouleComponentUpdate,组件每次更新之前,都要过一遍这个函数,如果返回true则更新,如果返回false则不更新,而默认情况下,这个函数会一直返回true,如果有一些无效的改动触发了这个函数,也会导致无效的更新!

什么是无效的改动?组件中propsstate一旦发生改变就会导致组件重新更新并渲染,但是如果props和state没有变化也莫名其妙的出发更新呢(有这种情况),就会导致无效渲染。

这里使用
this.shouldComponentUpdate=PureRenderMixin.shouldComponentUpdate.bind(this)的意思是重新组件的shouldComponentUpdate函数,在每次更新之前判断props和state,如果有变化返回ture,没有则返回false

因此,在开发过程中,在每个React组件都尽量使用PureRenderMixin

filter( ) 过滤器
如果给定表示 DOM 元素集合的 jQuery 对象,.filter() 方法会用匹配元素的子集构造一个新的 jQuery 对象。所使用的选择器会测试每个元素;所有匹配该选择器的元素都会包含在结果中。

$('li').filter(':even').css('background-color', 'red');
    //会选择偶数项使其背景色为红色 下标从0开始的

过滤函数
通过函数而不是选择器来筛选元素,对于每个元素,如果该函数返回true,则元素会被包含在已筛选的集合中,否则会排除这个元素

<ul>
  <li><strong>list</strong> item 1 - one strong tag</li>
  <li><strong>list</strong> item <strong>2</strong>
   - two <span>strong tags</span></li>
  <li>list item 3</li>
  <li>list item 4</li>
  <li>list item 5</li>
  <li>list item 6</li>
</ul>

//js代码  选取这些列表项,然后基于其内容来筛选它们:

$('li').filter(function(index) {
  return $('strong', this).length == 1;
}).css('background-color', 'red');
//tolist demo中的 可以不看这段代码
 this.setState({
             //遍历data 过滤数据
            todos: data.filter(item => {
                if (item.id !== id) {
                    return item
                }
            })
        })
  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值