当前位置:首页 > 科技  > 软件

React 函数组件不是有状态吗,为什么还要说他是纯函数

来源: 责编: 时间:2024-05-08 09:19:08 199观看
导读许多人在学习 React 时会有这样一个疑问,不断看到 React 官方团队言论,或者说各路大佬都是在说 React 是函数式编程,我们写组件确实写的是组件,但问题就在于,我们写的组件是有内部状态,这样的函数就不是纯函数了,这怎么能算

klK28资讯网——每日最新资讯28at.com

许多人在学习 React 时会有这样一个疑问,不断看到 React 官方团队言论,或者说各路大佬都是在说 React 是函数式编程,我们写组件确实写的是组件,但问题就在于,我们写的组件是有内部状态,这样的函数就不是纯函数了,这怎么能算是函数式编程呢?klK28资讯网——每日最新资讯28at.com

想不通。klK28资讯网——每日最新资讯28at.com

今天这篇文章,就来跟大家解释一下,为什么 React 的函数式组件,其实就是纯函数。klK28资讯网——每日最新资讯28at.com

UI = f(state)

一、hook 的特性

我们在声明一个函数式组件时,常常会使用到 hook 来声明一些状态或者方法,但是我们在使用 hook 时,你会发现 hook 会有一些奇怪的规则,那么就是不能把 hook 放到条件判断中去。klK28资讯网——每日最新资讯28at.com

if (a === 1) {  const [count, setCount] = useState(0)}

然后有的人就很不理解这个现象。于是把这个情况定性为 React 的设计缺陷。但这真的是设计缺陷吗?klK28资讯网——每日最新资讯28at.com

我们只需要换个思路,你就能对这个现象豁然开朗。klK28资讯网——每日最新资讯28at.com

二、hook 存在哪?

在初学阶段,我们会很自然的认为,当我们使用 useState 在函数内部定义了一个状态时,那么这个状态一定是保存在这个函数内部的。klK28资讯网——每日最新资讯28at.com

function Demo() {  const [count, setCount] = useState(0)  ...}

然后理解得多了,才发现并不是这样。每一个函数的状态都被存在了另外一个模块里(Fiber tree)。也就是说,只要 React 允许,我们甚至可以在别的组件访问到任意一个组件里的状态。当然 React 对这种情况做了限制,只允许通过特定的语法来做到这个事情。klK28资讯网——每日最新资讯28at.com

函数组件中的所有的 hook 都是从外部传入的。klK28资讯网——每日最新资讯28at.com

三、state 其实是参数

我们再来看一下这个公式。klK28资讯网——每日最新资讯28at.com

UI = f(state)

这个时候我们会恍然发现,虽然 state 在函数内部定义/获取了,但是很明显,React 是期望大家把他当成外部传入的参数来理解的。klK28资讯网——每日最新资讯28at.com

例如我们有这样一个函数。klK28资讯网——每日最新资讯28at.com

function Counter({x}) {  const [count, setCount] = useState(0)  return (    <div>{x + count}</div>  )}

他可以等价于。klK28资讯网——每日最新资讯28at.com

function Counter({x}, [count = 0, setCount]) {  return (    <div>{x + count}</div>  )}

这个时候我们就明朗了,函数,原来还是纯函数。但是为什么语法不这样设计呢,不是更好理解吗?当然是因为参数太多了写不下了呀,因此 React 把传参的行为,下放到了函数内部,通过 hook 的方式来实现。klK28资讯网——每日最新资讯28at.com

四、重新审视 hook

如果 state 是外部传入的参数,那么此时我们就要重新审视一下为什么不能把 hook 放到条件判断中去了。klK28资讯网——每日最新资讯28at.com

例如:klK28资讯网——每日最新资讯28at.com

function Counter({x}) {  if (a === 0) {    const [loading, setLoading] = useState(false)    }  const [count, setCount] = useState(0)  return (    <div>{x + count}</div>  )}

所以,useState 是外部传参,那么参数本来就应该有严格的顺序要求,这个时候如果第一个参数因为不符合条件而在代码逻辑里消失了,那第二个参数,不就变成第一个参数了吗?klK28资讯网——每日最新资讯28at.com

这个时候代码逻辑中,就会把第二个参数当成第一个参数去使用,这不就乱了吗?klK28资讯网——每日最新资讯28at.com

当我们调用 setState 时,表示入参正在发生变化,函数自然也会重新执行。klK28资讯网——每日最新资讯28at.com

五、总结

hook 存放在函数外部,因此不属于函数内部的状态。我们在理解函数式组件是纯函数时,应该把 hook 当成参数去看待,这样很多现象就非常自然了。klK28资讯网——每日最新资讯28at.com

函数式编程更加侧重于把逻辑解耦拆分成不同的函数,然后通过函数组合的形式去构建一个完整的逻辑,例如我们非常常见的 map 方法klK28资讯网——每日最新资讯28at.com

function func(item) {  return item + 1}var newArr = arr.map(func)

所以理解函数式编程,会对逻辑封装解耦的能力要求比较高,在这种情况下,理解函数式编程确实会存在一定的门槛。所以最后思考一个问题,为什么 state 一定要是不可变数据?klK28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-87257-0.htmlReact 函数组件不是有状态吗,为什么还要说他是纯函数

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: HTMX:重回前端的原始时代?

下一篇: 十项快速检查,确保你的 AWS 支出处于控制之中

标签:
  • 热门焦点
  • 红魔电竞平板评测:大屏幕硬实力

    前言:三年的疫情因为要上网课的原因激活了平板市场,如今网课的时代已经过去,大家的生活都恢复到了正轨,这也就意味着,真正考验平板电脑生存的环境来了。也就是面对着这种残酷的
  • 28个SpringBoot项目中常用注解,日常开发、求职面试不再懵圈

    前言在使用SpringBoot开发中或者在求职面试中都会使用到很多注解或者问到注解相关的知识。本文主要对一些常用的注解进行了总结,同时也会举出具体例子,供大家学习和参考。注解
  • 一文看懂为苹果Vision Pro开发应用程序

    译者 | 布加迪审校 | 重楼苹果的Vision Pro是一款混合现实(MR)头戴设备。Vision Pro结合了虚拟现实(VR)和增强现实(AR)的沉浸感。其高分辨率显示屏、先进的传感器和强大的处理能力
  • 三言两语说透设计模式的艺术-单例模式

    写在前面单例模式是一种常用的软件设计模式,它所创建的对象只有一个实例,且该实例易于被外界访问。单例对象由于只有一个实例,所以它可以方便地被系统中的其他对象共享,从而减少
  • JavaScript学习 -AES加密算法

    引言在当今数字化时代,前端应用程序扮演着重要角色,用户的敏感数据经常在前端进行加密和解密操作。然而,这样的操作在网络传输和存储中可能会受到恶意攻击的威胁。为了确保数据
  • 深度探索 Elasticsearch 8.X:function_score 参数解读与实战案例分析

    在 Elasticsearch 中,function_score 可以让我们在查询的同时对搜索结果进行自定义评分。function_score 提供了一系列的参数和函数让我们可以根据需求灵活地进行设置。近期
  • 雅柏威士忌多款单品价格大跌,泥煤顶流也不香了?

    来源 | 烈酒商业观察编 | 肖海林今年以来,威士忌市场开始出现了降温迹象,越来越多不断暴涨的网红威士忌也开始悄然回归市场理性。近日,LVMH集团旗下苏格兰威士忌品牌雅柏(Ardbeg
  • 猿辅导与新东方的两种“归途”

    作者|卓心月 出品|零态LT(ID:LingTai_LT)如何成为一家伟大企业?答案一定是对&ldquo;势&rdquo;的把握,这其中最关键的当属对企业战略的制定,且能够站在未来看现在,即使这其中的
  • 机构称Q2全球智能手机出货量同比下滑11% 苹果份额依旧第2

    7月20日消息,据外媒报道,研究机构的报告显示,由于需求下滑,今年二季度全球智能手机的出货量,同比下滑了11%,三星、苹果等主要厂商的销量,较去年同期均有下
Top