首页 > 其他分享 >面试官让你说说react状态管理?

面试官让你说说react状态管理?

时间:2022-11-15 08:33:34浏览次数:62  
标签:状态 面试官 React return react state 组件 view

开发者普遍认为状态是组件的一部分, 但是同时却又在剥离状态上不停的造轮子, 这不是很矛盾么?

对于一个最简单的文本组件而言

function Text(){
  const [text, setText] = useState('载入')
  return (){
    <p>{text}</p>
  }
}

你觉得应该把 text 从 Text 组件中剥离么? 如果你的直觉告诉你不应该这么做, 那为何要使用 redux mobx jotai 等等一系列稀奇古怪的状态管理库来让我们的代码变得更复杂?

所以 why?

还不是 React 自己的锅!!!

因为 React 在组件状态上给出了双重定义, 内敛的 state 和开放的 props.
同时因为 jsx 的限制导致组件通信只能依赖 props.

有人会说还有 context, 但如果你为组件通信单独增加一层 provide, 那随着应用膨胀, 你的状态会被 xml 结构割得四分五裂, 最后只剩下单一 store 这颗有毒药丸.

因为 React 天生状态同步上的缺陷, 才让状态管理这件事在 React 社区如此发达, 这其实是病态的.

想想战国时期群雄逐鹿吧. 还不是周天子失仪, 看看 Vue 就没有这么多狗屁倒灶的事.

状态管理生态的病态繁荣让整个 React 生态变得混乱.

不同状态管理库之间潜在的集成成本, 以及围绕这些状态管理打造的组件库又需要考虑集成. 看看 Route5 吧, 我觉得官网的 React 和 Redux 集成方案根本不够. 毕竟还有好几个库在那等着呢...

从 React 自身角度来看, 只要解决两个问题, 就没有所谓的状态管理了.

组件内部通信

jsx 下的组件结构无非两种, 包含和平级, 对于包含嵌套的结构, 单一 store 是可行的, 要解决的无非是内部的 jsx 片段之间如何共享和同步状态. 其实很简单只要给这些 jsx 片段绑定上一个共同的 context 就行了,参考 前端react面试题详细解答

import {createComponent} from 'structured-react-hook'

const Component = createComponent({
  initState:{
    A:'A',
    B:'B',
    M:'M',
  },
  view:{
    renderB(){
      return(
        <>
          <div>{this.state.M}</div>
          <div>{this.state.B}</div>
        </>
      )
    },
    renderA(){
      return(
        <>
          <div>{this.state.M}</div>
          <div>{this.state.A}</div>
        </>
      )
    },
    render(){
      return(
        <>
          <div>{this.state.M}</div>
          <div>{this.view.renderB()}</div>
          <div>{this.view.renderA()}</div>
        </>
      )
    }
  }
})

一个组件可以切分任一的 jsx 片段到 view 里, 同时将状态放在 initState 里管理, 在运行时让 render 函数的 this.state 指向 initState 就行了, 当然内部有些魔法, 这就不提了.

当然组件大了一定需要平行切割, 不然会遇到性能和维护上的问题. 对于平行组件如何让他们彼此共享和同步状态呢?

const ComponentA = createComponent({
  name:'ComponentA',
  initState:{
    A:'A'
  },
  view:{
    render(){
      return(
        <div>{this.combination.ComponentB.state.B}</div>
      )
    }
  }
})

const ComponentB = createComponent({
  name:'ComponentB',
  initState:{
    B:'B'
  },
  view:{
    render(){
      return(
        <div>{this.combination.ComponentA.state.A}</div>
      )
    }
  }
})

就这么简单, 只要让每个组件的实例能在彼此的 this 上互相感知, 操作和共享状态并不是难事.

这样对于 jsx 内平行的组件来说再也不需要为了通信而烦恼了. 无论跨越多少层, 最终我都会找到你.

所以解决这两个问题, 还需要额外的状态管理么?

至少在我看来状态管理是个伪命题, 组件和状态本身就是不可分割的一部分, 把状态视为组件的核心, 只要解决了组件的问题, 状态管理自然也就不是问题了

但是只要 React 官方不作为, 状态管理社区的病态繁荣还将继续持续下去

标签:状态,面试官,React,return,react,state,组件,view
From: https://www.cnblogs.com/beifeng1996/p/16891203.html

相关文章

  • 我的react面试题整理2(附答案)
    如何在React中使用innerHTML增加dangerouslySetInnerHTML属性,并且传入对象的属性名叫_htmlfunctionComponent(props){return<divdangerouslySetInnerHTML={{_htm......
  • React组件基础四
    一.组件生命周期概述意义:组件的生命周期有助于理解组件的运行方式、完成更复杂的组件功能、分析组件错误原因等组件的生命周期:组件从被创建到挂载到页面中运行,再到组......
  • 66.有没有碰到过数组响应丢失(问的是ref和reactive的用法,什么情况下用)
    由于vue3使用proxy,对于对象和数组都不能直接整个赋值。  直接赋值丢失了响应性只有push或者根据索引遍历赋值才可以保留reactive数组的响应性 ;可以使用toRefs解决......
  • 为什么只有状态转移算法才是真正意义上的智能优化算法,其它的都是“假冒伪劣”?
    0旁白    长期以来,“论文为王”的观念被推崇至上,没有论文就没有发言权,发表了大量学术论文才能高谈阔论、坐而论道,以至于出现“大家都忙着写论文,没有时间搞科研”......
  • Reactor模式
    Reactor模式基本设计思想,简单来讲就是I/O复用结合线程池 Reactor模式,是指通过一个或多个输入同时传递给服务处理器的服务请求的事件驱动处理模式。服务端程序处理传......
  • 59.ref和reactive的区别
    首先,ref和reactive定义响应式数据的,&vue3中的数据分为2类,一类没有响应式数据第二类是响应式数据;如果没有使用ref或者reactive定义数据,那么默认是第一类没有响应......
  • 状态码400
    400是HTTP的状态码,主要有两种形式:1、badrequest意思是“错误的请求”;2、invalidhostname意思是“不存在的域名”。400BadRequest是由于明显的客户端错误(......
  • 「React」PropTypes提供的验证器
    前言通常,我们在项目中使用自定义组件时,需要对组件的props进行类型检测。而React提供了专门的库,可以校验组件的props类型,也可以做一些特定的限制。下面行详细介绍。以下内容......
  • react项目--路由封装
    importReact,{lazy}from"react";importHomefrom"../views/Home";importLoginfrom"@/views/Login";constPage1=lazy(()=>import("../views/Page1"));......
  • react项目--redux封装
    index.ts1conststore={2state:{3num:20,4},5actions:{6//放同步的代码7add1(newState:{num:number},action:{t......