React16.8组件代码复用的4种方式

栏目: 服务器 · 发布时间: 6年前

内容简介:一、关于自定义二、使用自定义
  • 1、定义一个高阶组件

    import React from 'react';
    
    function withCounter(Component) {
      return class extends React.Component {
        state = { number: 0 };
        componentDidMount() {
          setInterval(() => {
            this.setState({ number: this.state.number + 1 });
          }, 1000);
        }
        render() {
          return (
            <Component number={this.state.number} />
          )
        }
      }
    }
    复制代码
  • 2、普通组件的代码

    class ReuseComponent1 extends React.Component {
      render() {
        return (
          <>
            <button>{this.props.number}</button>
          </>
        )
      }
    }
    复制代码
  • 3、使用高阶组件将普通组件包装

    export default withCounter(ReuseComponent1);
    复制代码

三、使用 render 函数使组件达到复用

  • 1、定义组件

    import React, { Component } from 'react'
    
    export default class ReuseComponent2 extends Component {
      state = { number: 0 };
    
      componentDidMount() {
        setInterval(() => {
          this.setState({ number: this.state.number + 1 });
        }, 1000);
      }
      render() {
        return (
          <div>
            {/* 直接调用传递过来的render属性(这里传递的是一个函数) */}
            {this.props.render({ number: this.state.number })}
          </div>
        )
      }
    }
    复制代码
  • 2、组件的调用

    // render里面传递的是一个函数
    <ReuseComponent2 render={props => <p>{props.number}</p>} />
    复制代码

四、使用自定义 hooks

一、关于自定义 hooks 的认识

  • 1、有时候我们会想要在组件之间重用一些状态逻辑
  • 2、自定义 Hook 可以让你在不增加组件的情况下达到同样的目的
  • 3、 Hook 是一种复用状态逻辑的方式,它不复用 state 本身
  • 4、事实上 Hook 的每次调用都有一个完全独立的 state
  • 5、自定义 Hook 更像是一种约定,而不是一种功能。如果函数的名字以 use 开头,并且调用了其他的 Hook ,则就称其为一个自定义 Hook

二、使用自定义 hooks 达到代码的复用

  • 1、自定义 hooks 函数

    import React, { useState, useEffect } from 'react';
    
    /**
     * 自定义hooks,以use开头的名字并且使用内置的hooks
     */
    function useNumber() {
      let [number, setNumber] = useState(0);
    
      useEffect(() => {
        setInterval(() => {
          setNumber(number => number + 1);
        }, 1000);
      }, []);
    
      return [number, setNumber];
    }
    复制代码
  • 2、使用

    export default () => {
      let [number, setNumber] = useNumber();
      return (
        <div>{number}</div>
      )
    }
    复制代码

以上就是本文的全部内容,希望本文的内容对大家的学习或者工作能带来一定的帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

算法设计与分析

算法设计与分析

张德富 / 2009-8 / 36.00元

《算法设计与分析》主要取材于算法设计与分析领域的经典内容,并介绍了算法设计的发展趋势。内容主要包括非常经典的算法设计技术,例如递归与分治、动态规划、贪心、回溯、分支限界、图算法,也包括了一些高级的算法设计主题,例如网络流和匹配、启发式搜索、线性规划、数论以及计算几何。在算法分析方面,介绍了概率分析以及最新的分摊分析和实验分析方法。在算法的理论方面,介绍了问题的下界、算法的正确性证明以及NP完全理论......一起来看看 《算法设计与分析》 这本书的介绍吧!

在线进制转换器
在线进制转换器

各进制数互转换器

UNIX 时间戳转换
UNIX 时间戳转换

UNIX 时间戳转换

HEX HSV 转换工具
HEX HSV 转换工具

HEX HSV 互换工具