返回顶部
首页 > 资讯 > 精选 >React函数组件与类组件怎么使用
  • 170
分享到

React函数组件与类组件怎么使用

2023-06-30 08:06:56 170人浏览 薄情痞子
摘要

这篇“React函数组件与类组件怎么使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“React函数组件与类组件怎么使用”文

这篇“React数组件与类组件怎么使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“React函数组件与类组件怎么使用”文章吧。

    一、类组件的问题

    自从React推出Hooks之后,函数组件写法大行其道,而类组件写法日渐式微。为什么会这样呢? 我觉得有以下三个原因:

    原因一、因为this带来的问题:

    有一个著名的案例展示了类组件this带来的问题,下面我将其本土化复现一下这个案例。

    import React from "react"const ProfileFunction: React.FC<{Goods:string}> = (props) => {    const showMessage = () => {        alert(`你下单的是“${props.goods}”!` )    }    const handleClick = () => {        setTimeout(showMessage, 3 * 1000)    }    return (        <button onClick={handleClick}>购买</button>    )}class ProfileClass extends React.Component<    { goods: string },  // props 类型    {}  // state 类型> {    showMessage = () => {        alert(`你下单的是“${this.props.goods}”!` )    }    handleClick = () => {        setTimeout(this.showMessage, 3 * 1000)    }    render() {        return <button onClick={this.handleClick}>购买</button>    }}export default class App extends React.Component {    state = {        goods: '苹果',    };    render() {        return (            <>                <label>                    请选择:                    <select                        value={this.state.goods}                        onChange={e => this.setState({ goods: e.target.value })}                    >                        <option value="苹果">苹果</option>                        <option value="香蕉">香蕉</option>                        <option value="西瓜">西瓜</option>                    </select>                </label>                <h2>{this.state.goods}</h2>                <p>                    <ProfileFunction goods={this.state.goods} />                    <b> (function)</b>                </p>                <p>                    <ProfileClass goods={this.state.goods} />                    <b> (class)</b>                </p>            </>        )    }}

    这里有在线案例,有兴趣的朋友可以在线体验一下这个案例。

    问题描述

    React函数组件与类组件怎么使用

    • 函数组件:当用户选择苹果,点击购买后,再切换浏览香蕉,提示信息反馈用户下单的是苹果。

    • 类 组 件 :当用户选择苹果,点击购买后,再切换浏览西瓜,提示信息反馈用户下单的是西瓜!

    问题解析

    粗看函数组件和类组件的代码,都是返回一个按钮,该按钮3秒(模拟网络延迟)后会弹出一个alert提示用户下单的商品。为什么结果不一致呢? 参数props本身是不可变的,函数组件中的showMessage在3秒延迟后拿到的仍然是原来的props.goods。 但是类组件中实例的this是可变的,类组件中的showMessage在3秒延迟后去拿this.props.goods时,由于this发生了变化,所以造成取到的值不是原来的值。

    原因二、类组件代码量比函数组件多:

    这个从上面的案例中可见一斑,同样功能的函数组件代码量比类组件少一些。

    原因三、类组件过于臃肿不易拆分:

    类组件和函数组件最大的不同还在于代码思路方面的不同。类组件是面向对象编程思维方式,函数组件是面向过程编程思维方式。React的设计思路更推崇组合,而不是继承。在类组件中大量使用继承会造成组件过重,功能难以拆分。

    二、函数组件的问题

    函数组件以前被叫做无状态组件,就是因为函数组件内部不能保存state。自从react官方推出各类hooks后,函数式组件变得越来越流行。react官方宣称将来会推出更多hooks以实现所有类组件的功能,不过这个flag立了挺久的,至今还有很多没有实现。 下面来按生命周期的顺序盘点一下类组件的方法与函数组件对应的hooks。

    挂载阶段:getDerviedStateFromProps VS 无

    • 该方法用于在props被传入后根据props更新state。

    • 函数组件中也可以写代码根据props更新state,但这样做会造成重复渲染。如果遇到需要根据props更新state的情况,应该考虑做状态提升。如果你发现在某个组件中必须要根据props更新state又无法做状态提升,那么该组件应该写成类式组件,而不是函数式组件。

    挂载阶段:UNSAFE_componentWillMount VS 无

    • 该方法用于在组件挂载之前处理一些逻辑,但它在异步渲染模式下容易造成重复调用,react官方已将其标记为废弃。

    • 函数组件可以无视该方法。

    挂载阶段:componentDidMount VS useEffect

    • 该方法用于在组件挂载以后执行副作用操作,如发起网络请求、设置计时器、创建订阅等。

    • 函数组件有useEffect。

    render:

    • 在类组件的render方法中返回要渲染的内容。render里不能有副作用和setState!

    • 函数组件的return和类组件render方法的return效果一致。

    生命周期,更新阶段:UNSAFE_componentWillRerciveProps VS 无

    • 该方法作用跟getDerviedStateFromProps的一样,都是在组件挂载之前处理一些逻辑,但react官方已将其标记为废弃。

    • 函数组件可以无视该方法。

    生命周期,更新阶段:getDerviedStateFromProps VS 无

    同挂载阶段的同名方法一样。

    生命周期,更新阶段:shouldComponentUpdate VS memo、useMemo、useCallback

    • 该方法返回true表示需要更新、返回false表示无需更新。可在此添加判断条件做性能优化,另外PureComponent实现原理也相同。

    • 函数组件对应的hooks有很多,常用的有memo、useMemo、useCallback,同样可以做性能优化

    生命周期,更新阶段:UNSAFE_componentWillUpdate VS 无

    • 该方法原来在组件重新渲染之前做一些操作,react官方已将其标记为废弃。

    • 函数组件可以无视该方法。

    render:

    同挂载阶段一样。

    生命周期,更新阶段:getSnapshotBeforeUpdate VS 无

    • 该方法在最近一次渲染输出(提交到DOM节点)之前调用。它使得组件能在发生更改之前从DOM中捕获一些信息(如滚动位置等)。此生命周期方法的任何返回值将作为参数传递给componentDidUpdate()。此用法并不常见,但它可能出现在UI 处理中,如以特殊方式处理滚动位置的聊天线程等。

    • 函数组件无该方法对应的hooks。

    生命周期,更新阶段:componentDidUpdate VS 无

    • 组件更新后会立即调用该方法,首次渲染不会调用。当组件更新后,可以在此处对DOM进行操作。注意:在该方法中慎用setState,如果要用必须将其包裹在条件语句里。

    • 函数组件无该方法对应的hooks,因为React本身设计是减少直接操作DOM,在React中除了useRef外直接操作DOM的场景很少,函数组件没有该方法对应的hooks不算什么问题。

    生命周期,卸载阶段:componentWillUnmount VS useEffect

    • 该方法会在组件卸载及销毁之前直接调用。在此方法中执行必要的清理操作,例如:清除计时器、取消网络请求或清除订阅等。

    • 函数组件有useEffect。

    其他,错误边界:componentDidCatch、static getDerivedStateFromError VS 无

    • 在类组件中定义了static getDerivedStateFromError或componentDidCatch这两个生命周期方法中的任意一个或两个时,那么它就变成一个错误边界。当抛出错误后,请使用static getDerivedStateFromError渲染备用UI,使用componentDidCatch打印错误信息。

    • 函数组件无错误边界对应的hooks

    以上就是关于“React函数组件与类组件怎么使用”这篇文章的内容,相信大家都有了一定的了解,希望小编分享的内容对大家有帮助,若想了解更多相关的知识内容,请关注编程网精选频道。

    --结束END--

    本文标题: React函数组件与类组件怎么使用

    本文链接: https://lsjlt.com/news/327809.html(转载时请注明来源链接)

    有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

    猜你喜欢
    • React函数组件与类组件怎么使用
      这篇“React函数组件与类组件怎么使用”文章的知识点大部分人都不太理解,所以小编给大家总结了以下内容,内容详细,步骤清晰,具有一定的借鉴价值,希望大家阅读完这篇文章能有所收获,下面我们一起来看看这篇“React函数组件与类组件怎么使用”文...
      99+
      2023-06-30
    • React函数组件与类组件使用及优劣对比
      目录一、类组件的问题原因一、因为this带来的问题:问题描述问题解析原因二、类组件代码量比函数组件多:原因三、类组件过于臃肿不易拆分:二、函数组件的问题挂载阶段:getDervied...
      99+
      2024-04-02
    • React函数式组件与类组件的不同点是什么
      本文小编为大家详细介绍“React函数式组件与类组件的不同点是什么”,内容详细,步骤清晰,细节处理妥当,希望这篇“React函数式组件与类组件的不同点是什么”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。区别区别函...
      99+
      2023-06-29
    • React 函数式组件和类式组件详情
      目录前言1. 函数式组件2. 类式组件前言 React 是 组件化的 的 JS 库,组件化 也是 React 的核心思想。使用 React 可以构建管理...
      99+
      2022-11-13
      React 函数式组件 React 类式组件
    • React函数式组件与类组件的不同你知道吗
      目录区别其他区别总结区别 区别函数组件类组件生命周期无有this无有state无有改变stateReact Hooks:useStatethis.setState()性能高(不用实例...
      99+
      2024-04-02
    • react生命周期的类组件和函数组件怎么写
      这篇文章主要介绍“react生命周期的类组件和函数组件怎么写”,在日常操作中,相信很多人在react生命周期的类组件和函数组件怎么写问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”react生命周期的类组件和函...
      99+
      2023-07-04
    • react类组件和函数组件区别有哪些
      React 类组件和函数组件是两种不同的组件写法,它们之间有以下几个主要区别:1. 语法:React 类组件是通过 ES6 的 cl...
      99+
      2023-10-07
      react
    • React函数组件与类的区别有哪些
      目录一、函数式组件捕获了渲染所用的值二、闭包让类组件成为拥有特定props和state的渲染三、区分useState与useRef的使用首先我们要知道的是,项目性能能主要取决于代码的...
      99+
      2022-11-13
      React函数组件与类 React函数组件
    • react函数组件对比类组件有哪些优势
      这篇文章主要讲解了“react函数组件对比类组件有哪些优势”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“react函数组件对比类组件有哪些优势”吧! ...
      99+
      2024-04-02
    • React函数组件和类组件的区别及说明
      目录React函数组件和类组件区别函数组件类组件区别React函数式组件和类组件的优缺点1.类组件的性能消耗比较大2.函数式组件性能消耗小React函数组件和类组件区别 定义组件有两...
      99+
      2022-11-13
      React函数组件 React类组件 React函数
    • react生命周期(类组件/函数组件)操作代码
      1.react代码模式分为两种 类组件和函数组件(生命周期也有所不同) 2.类组件(写法如下) import React from 'react' export default cl...
      99+
      2023-01-06
      react生命周期 react类组件 react函数组件
    • 使用 TypeScript 开发 React 函数式组件
      目录前言如何使用 TypeScript 定义函数式组件1. 使用 React.FC2. 使用 JSX.Element3. 直接定义完整类型4. 使用 React.PropsWithC...
      99+
      2024-04-02
    • ReactuseContext与useReducer函数组件使用
      目录useContext介绍使用useReducer介绍使用(简单示例实现计算器)将useContext与useReducer整合useContext 介绍 与class中写法对比减...
      99+
      2023-02-06
      React useContext React useReducer
    • React组件怎么转Vue组件
      本篇内容主要讲解“React组件怎么转Vue组件”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“React组件怎么转Vue组件”吧!简介对于react-to-vu...
      99+
      2024-04-02
    • react-native 父函数组件调用类子组件的方法(实例详解)
      react-native 父函数组件调用类子组件的方法,代码如下所示: import React, {Component} from 'react'; import {Text, V...
      99+
      2024-04-02
    • react为什么推荐函数组件
      本教程操作环境:Windows7系统、react18版、Dell G3电脑。当使用React框架开发的时候,有两种方式创建组件,使用函数和使用类,目前函数组件越来越流行。下面通过举例的方式,分析函数组件和类组件的不同,并总结一下使用函数组件...
      99+
      2023-05-14
      javascript React
    • React组件useReducer的讲解与使用
      目录useReducer的使用刨析useReducer参数useReducer的使用useReducer的使用 在React函数式组件中,我们可以通过useState()来创建sta...
      99+
      2023-05-16
      React组件useReducer useReducer使用 useReducer讲解
    • React组件与事件的创建使用教程
      目录创建组件函数组件类组件组件提取到单独的文件中有状态组件与无状态组件类组件的状态事件处理创建组件 函数组件 函数组件:使用JS的函数或者箭头函数创建的组件 使用 JS 的函数(或箭...
      99+
      2023-02-10
      React组件 React事件 React组件与事件
    • React中怎么实现受控组件与非受控组件
      本篇文章给大家分享的是有关React中怎么实现受控组件与非受控组件,小编觉得挺实用的,因此分享给大家学习,希望大家阅读完这篇文章后可以有所收获,话不多说,跟着小编一起来看看吧。受控组件与非受控组件是Reac...
      99+
      2024-04-02
    • React组件如何使用
      本篇内容主要讲解“React组件如何使用”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“React组件如何使用”吧!组件的定义:理解:用来实现局部功能效果的代码和资源的集合(html/css/js...
      99+
      2023-07-05
    软考高级职称资格查询
    编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
    • 官方手机版

    • 微信公众号

    • 商务合作