React中PureComponent 和 Component区别

更新日期: 2019-09-07阅读: 2.1k标签: Component

我们来看一看 Component 和 PureComponent 的区别,我们先从问题出发,通过解决实际的问题来查询出 PureComponent 和 Component 之间区别。这里创建 Greeting 的组件,其中我们用 setInterval 每间隔 2 秒就更新状态title一次,然后在 6 秒后调用 clearInterval 方法来取消这个打点器。

import react, { Component,Fragment } from 'react'

import TutSubtitle from './TutSubtitle'
import TutTitle from './TutTitle'

export default class Greeting extends Component {
    constructor(props){
        super(props);
        this.state = {
            title:Math.random(),
            subTitle:Math.random()
        }
    }

    componentDidMount(){
        const id = setInterval(() => this.setState({title: Math.random()}),2000);
        setTimeout(()=> clearInterval(id),6000);
        
    }
  render() {
    return (
      <Fragment>
        <TutTitle name={this.state.title}/>
        <TutSubtitle name={this.state.subTitle}/>
      </Fragment>
    )
  }
}

下面创建了个组件被别是 TutTitle 和 TutSubTitle

import React, { Component } from 'react'

export default class TutTitle extends Component {
  render() {
      console.log('rendering tut title ...');
    return (
      <div>
        <span>{this.props.name}</span>
      </div>
    )
  }
}

import React, { Component } from 'react'

export default class TutSubtitle extends Component {
  render() {
      console.log('rendering sub tittle...')
    return (
        <div>
        <span>{this.props.name}</span>
      </div>
    )
  }
}

其实我们每次只是更新状态 state 的 title 值,但是更新时同时也渲染 SubTitle

rendering tut title ...
TutSubtitle.js:5 rendering sub tittle...
TutTitle.js:5 rendering tut title ...
TutSubtitle.js:5 rendering sub tittle...
TutTitle.js:5 rendering tut title ...
TutSubtitle.js:5 rendering sub tittle...
TutTitle.js:5 rendering tut title ...
TutSubtitle.js:5 rendering sub tittle...

我们可以通过 shouldComponentUpdate 来阻止组件跟随其父级组件 state 的变化而更新。如果在 shouldComponentUpdate 返回 true 时,只要父级组件 state 更新其就随之更新。

    shouldComponentUpdate(nextProps, nextState, nextContext) {
         return false;
    }

也可以更精确地进行控制通过对比 nextProps.name !== this.props.name;来实现。

    shouldComponentUpdate(nextProps, nextState, nextContext) {
         return nextProps.name !== this.props.name;
    }

完整代码如下

export default class TutSubtitle extends Component {

    shouldComponentUpdate(nextProps, nextState, nextContext) {
         return nextProps.name !== this.props.name;
    }
  render() {
      console.log('rendering sub tittle...')
    return (
        <div>
        <span>{this.props.name}</span>
      </div>
    )
  }
}

当然可以使用 PureComponent 类型来创建 Subtitle 组件,因为 PureComponent 的特殊性我们就无需做额外工作也能够达到预期的效果。

在 PureComponent 在使用 shouldComponentUpdate的处理是由 PureComponent 自身来处理,而不是由用户来控制,所以我们在 PureComponent 中如果复写此生命周期回调函数,React 会提示我们错误的。告诉我们不允许重写该方法。

    shouldComponentUpdate(nextProps, nextState, nextContext) {
         return nextProps.name !== this.props.name;
    }

以上就是通过实际开发场景来分享 PureComponent 与 Component 的不同之处。

链接: https://fly63.com/article/detial/5781

javascript字符串进行编码的方法:escape编码、encodeURI编码、encodeURIComponent编码

js对字符串进行编码的方法。ECMAScript v3 反对使用escape方法,用 encodeURI() 和 encodeURIComponent() 替代它。encodeURI对URI 进行完整的编码,因此对以下在 URI 中具有特殊含义的 ASCII 标点符号,encodeURI() 函数是不会进行转义的。

使用纯粹的JS构建 Web Component

Web Component 出现有一阵子了。 Google 费了很大力气去推动它更广泛的应用,但是除 Opera 和 Chrome 以外的多数主流浏览器对它的支持仍然不够理想。Web Component 是一系列 web 平台的 API,它们可以允许你创建全新可定制、可重用并且封装的 HTML 标签,从而在普通网页及 web 应用中使用。

ReactJS Components: 基础指南

创建和管理React组件的各种方式,涌现的大量状态管理工具等等都是这些挑战的焦点。我们今天能做的就是在React(基于社区选择)中将最常用的做法引入桌面并讨论它们。

从VantComponent 谈小程序维护

在开发小程序的时候,我们总是期望用以往的技术规范和语法特点来书写当前的小程序,所以才会有各色的小程序框架,例如 mpvue、taro 等这些编译型框架

react如何通过shouldComponentUpdate来减少重复渲染

在react开发中,经常会遇到组件重复渲染的问题,父组件一个state的变化,就会导致以该组件的所有子组件都重写render,尽管绝大多数子组件的props没有变化

react中的element、component、instance的理解

在React中无论是class形式(render函数)还是function形式(return的内容)的组件,最后返回的jsx其实质是React.createElement函数的结果,而React.createElement函数返回的结果是一个对象树,我们可以称之为元素描述树

如何评价 Vue 的 Function-based Component?

react 的不可变,纯函数。直接导致 hooks 必须使用 const 关键字,不能是 let,这也是 hooks 的奇迹之一;Hooks对Fiber更好 -> Hooks是Fiber的产物 -> 没有Fiber就不是Hooks

React Server Component 可能并没有那么香

前段时间 React 团队发布了一项用于解决 React 页面在多接口请求下的性能问题的解决方案 React Server Components。当然该方案目前还在草案阶段,官方也只是发了视频和一个示例 demo 来说明这个草案。

Vue.js 中使用defineAsyncComponent 延迟加载组件

使用 Vue 3 的 defineAsyncComponent 特性可以让我们延迟加载组件。这意味着它们仅在需要时从服务器加载。这是改善初始页面加载的好方法,因为我们的应用程序将以较小的块加载,而不必在页面加载时加载每个组件。

Web Components中引入外部CSS的8种方法

开发中,还是会遇到需要引入外部CSS到Shadow DOM情况,那么如何处理呢?作者就最近遇到的情况给出如下几种方案。

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!