React的使用:React组件内部的状态管理

这篇文章给大家介绍的内容是关于React的使用:React组件内部的状态管理,有着一定的参考价值,有需要的朋友可以参考一下。

在本文中,我们将把目光聚焦于 React 组件内部的状态管理,去认识或重新思考以下三个核心概念:

props 和 state

函数组件

类组件

让我们开始吧!

01. React 中的数据

站在“组件”的角度上,React 把应用中流动的数据分为两种类型:

不可更改内容,但可以单向跨组件传递的 props;

可以更改内容,但不能跨组件传递的 state;

进一步说,props 和 state 的区别在于,props 是外部的,并且被任何渲染这个组件的代码所控制。而 state 则是内部的,并且被组件自身所控制。

非计算机专业的初学者经常困惑 props 和 state 在名称与含义上的关联,其实大可不必在意,他们本质上只是数据的别称,只是在 React 中,它们被各自赋予了特殊的限制或能力。

你可以通过组件上的 props 属性,像在 HTML 中传递属性一样,将你想要传递的任何数据传递给子组件,所有的属性都会被存储在子组件(类组件)的 this.props 对象中。

function Parent(props) {    return }function Child(props) {    return (props.name)}

登录后复制

02. 函数组件

我们之前提到过,React 使用组件渲染视图提升性能,而组件即是一个函数,可以用一个公式来简洁的表示其功用:f(数据) => UI。到这里我想你应该注意到了,为什么我们说 React 并不是一个大型的 MVC (或 MVVM)框架,因为 React 只负责视图层(View)的渲染,其他的事情将由 React 生态中的其他工具来完成。

话说回来,对于 React 组件而言,最简单的一种形式莫过于函数组件了,它充分展现了 React 的哲学,一次只做一件事,组件化和数据驱动UI。

函数组件又称为“无状态组件”,“受控组件”或“木偶组件”,因为函数组件只负责接收 props 并返回 UI,它自身并不能拥有可改变的数据,在真实的 React 应用开发场景下,我们经常尽可能的使用函数组件,将整个应用的 UI 拆分成尽可能小的视觉单元。

这是因为函数组件是非常直观的,它接收属性返回元素,内部逻辑清晰明确,而且更重要的是,函数组件内没有 this 关键字,因此你永远不用担心烦人的“this上下文问题”。

记住:如果你的组件不需要追踪内部状态,尽量使用函数组件。

03. 类组件

和函数组件相对应的,便是“类组件”了,类似的,它也被称为“有状态组件”,“非受控组件”和“容器组件”。这里需要注意,虽然我们按照代码的形式为两种类型的组件命名,但这并不严谨,因为在 JavaScript 中,“类”也是函数。

不同于函数组件,类组件拥有着可以更改的内部数据 — state。它最终影响着页面的渲染情况,而且 state 可以被组件在任何时刻在内部修改。通常的时刻时用户与界面发生交互的时候。

由于 React 把变化的数据封装在组件内部,并坚持单向数据流的原则。我们有了高度抽象的 UI 组件,并封装复杂的业务逻辑。这使得我们可以通过构建,组合一系列小组件开发出大型应用。

那么应该如何向类组件添加 state 呢?很简单,我们所要做的只是在类组件内部添加一个 state 属性,state 属性是一个对象。这个对象代表了组件的状态,对象的每一个属性名都代表组件的一个特定的状态,下面是具体的代码:

import React from "react"class Parent extends React.Component {    state = {        name: "Eliot",    }        render() {        return 

{this.state.name}

}}

登录后复制

React 使我们迫使大脑关注两个重要的部分:

组件看起来是什么样?

组件当前的状态是什么?

通过让组件管理自己的状态,任何时候状态的变更都会令 React 自动更新相应的页面部分。这便是使用 React 构建组件的主要优势之一:当页面需要重新渲染时,我们仅仅需要思考的是如何更改状态。我们不必跟踪页面的哪些部分需要更改,不需要决定如何有效的重新呈现页面,React 自会比较先前的输出和新的输出,决定什么应该发生改变,并为我们做出决定。而这个确定之前改变了什么和现在应该新输出什么的过程有一个专门的名词,叫做 Reconciliation。

04. 修改 state

你应该还记得类组件与函数组件最大的不同在于类组件自身拥有可以改变内部数据的能力。那么如何行使这一能力呢?和直觉不同,要做到这一点,你需要使用 React 提供的专门的 API:this.setState()。

你有两种方式使用该 API:

设置对象参数;

设置函数参数;

让我们先来看看第一种:

this.setState({    name: "Tom"})

登录后复制

React 会自动合并对 state 的改变。而有时,你的组件需要一个新的 state ,而这个 state 的变化又依赖于旧的 state值,每当这种时候,你就该使用第二种 API 调用方式:

this.setState((prevState) => ({    name: "mr." + prevState.name}))

登录后复制

讲到这里你可能会感到奇怪,只是更新 state 而已,为什么还需要调用一个专门的 API?我们直接修改之前定义的 state对象不就好了吗?之所以这样设计的原因是,组件内 state 的变化不仅仅是对象属性值发生变化那么简单,它还需要驱动整个 UI 进行重新渲染,因此 this.setState() 这个 API 被调用时实际上做了两件事:

修改 state 对象;

驱动组件重新渲染;

如果你对 React 有一定研究,你可能会质疑我以上所罗列的两点并不精确,的确如此,小小的 this.setState() API 其实内部还有很多细节值得注意,例如,当调用 this.setState() 时并不会立即改变 state 的值,也当然不会立即重新渲染组件。例如,当以对象为参数调用 this.setState() API 时,尽管内部重复为数据赋值,最终的数据也只保留最后一次更改的结果。

不过幸好,这些略显古怪的状态早有前人为我们做了详尽的解释,如果你感兴趣,请点击下方链接查询更多的信息:

setState:这个API设计到底怎么样

问一个react更新State的问题?

05. 控制组件

当你在 Web 应用中使用表单时,这个表单的数据被存储于相应的 DOM 节点内部,但正如我们之前提到的,React 的整个关键点就在于如何高效的管理应用内的状态。所以虽然表单的数据被存储于 DOM 中,React 依然可以对它进行状态管理。

而管理的方式即是使用“控制组件”。简单而言,“控制组件”会渲染出一个表单,但是将表单所需的所有真实数据作为 state 存储于组件内部,而不是 DOM 中。

之所以被称为“控制组件”的原因也即在于此,“控制组件”控制着组件内的表单数据,因此,唯一更新表单数据的方式就是更新组件内部对应的 state 值。

import React as "react"class Input extends React.Component {    state = {        value: "enter something...",    }        handleClick: (e) => {        this.setState({value: e.target.value})    }        render() {            }}

登录后复制

可以看到,我们使用 handleClick 方法响应用户每一次键盘敲击以即时更新表单状态,这样做不仅天然的支持了即时的输入验证,还允许你有条件的禁止或点亮表单按钮。

06. 小结

这篇文章我们介绍了 React 的两种数据形式:state 和 props,并且介绍了 React 组件的两种形式:函数组件与类组件,希望各位有所收获。

相关推荐:

react的使用: React如何渲染UI

React的使用:react框架的五大特点

以上就是React的使用:React组件内部的状态管理的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2745722.html

(0)
上一篇 2025年3月8日 03:48:33
下一篇 2025年3月8日 03:48:38

AD推荐 黄金广告位招租... 更多推荐

相关推荐

  • react的使用: React如何渲染UI

    这篇文章给大家介绍的内容是关于react的使用: react如何渲染ui,有着一定的参考价值,有需要的朋友可以参考一下。 01. React 渲染界面的方式 在 React 等大型前端框架出现之前,我们渲染 UI 元素的方式是使用字符串模板…

    编程技术 2025年3月8日
    000
  • vue-cli的单元测试的示例解析

    这篇文章给大家介绍的内容是关于vue-cli的单元测试的示例解析,有着一定的参考价值,有需要的朋友可以参考一下。 vue-cli的单元测试 最近项目开发临近结尾,反思之前做的不足的地方,想着应该引入测试类的做法,于是乎开始学习前端测试之类的…

    编程技术 2025年3月8日
    200
  • JavaScript中Object.defineProperty()方法的解析

    这篇文章给大家介绍的内容是关于javascript中object.defineproperty()方法的解析,有着一定的参考价值,有需要的朋友可以参考一下。 =与Object.defineProperty 为JavaScript对象新增或者…

    编程技术 2025年3月8日
    200
  • js如何实现将上传图片并且压缩的方法

    这篇文章给大家介绍的内容是关于js上传图片压缩,有着一定的参考价值,有需要的朋友可以参考一下。 js实现图片压缩后上传 用到的技术: canvas相关api html5的一些api 兼容性: 点击下载“嗨格式压缩大师”; h5没发现问题,p…

    编程技术 2025年3月8日
    200
  • js实现重建二叉树的算法解析

    这篇文章给大家介绍的内容是关于js实现重建二叉树的算法解析,有着一定的参考价值,有需要的朋友可以参考一下。 题目描述 输入某二叉树的前序遍历和中序遍历的结果,请重建出该二叉树。假设输入的前序遍历和中序遍历的结果中都不含重复的数字。例如输入前…

    编程技术 2025年3月8日
    200
  • React中动画不生效的原因分析

    这篇文章给大家介绍的内容是关于react中动画不生效的原因分析,有着一定的参考价值,有需要的朋友可以参考一下。 项目中需要做这样的一个组件根据不同的数值,这个蓝色的条显示的宽度不同。这个其实很简单,我只要根据数据动态的计算它的宽度,生成节点…

    编程技术 2025年3月8日
    200
  • React Event事件注册的实现

    这篇文章给大家介绍的内容是关于react event事件注册的实现,有着一定的参考价值,有需要的朋友可以参考一下。 React 元素的事件处理和 DOM元素的很相似。但是有一点语法上的不同: React事件绑定属性的命名采用驼峰式写法,而不…

    2025年3月8日
    200
  • 原生JS如何动态加载JS和CSS文件以及代码脚本

    这篇文章给大家介绍的内容是关于原生js如何动态加载js和css文件以及代码脚本,有着一定的参考价值,有需要的朋友可以参考一下。 DOM readyState属性共5中状态 uninitialized:初始状态 loading:documen…

    编程技术 2025年3月8日
    200
  • JS作用域和面向对象的进一步解析

    以上就是JS作用域和面向对象的进一步解析的详细内容,更多请关注【创想鸟】其它相关文章!

    编程技术 2025年3月8日
    200
  • 浅析javascript中事件流的内容

    这篇文章给大家介绍的内容是关于浅析javascript中事件流的内容,有着一定的参考价值,有需要的朋友可以参考一下。 事件通常与函数配合使用,这样就可以通过发生的事件来驱动函数执行,事件是可以被 JavaScript 侦测到的行为 绑定事件…

    2025年3月8日 编程技术
    200

发表回复

登录后才能评论