首页
学习
活动
专区
圈层
工具
发布

聊聊两个状态管理库 Redux & Recoil

Atom 简单理解一下,atom 是包含了一份数据的集合,这个集合是可共享,可修改的。 组件可以订阅atom, 可以是一个, 也可以是多个,当 atom 发生改变时,触发再次渲染。...相对于整个应用程序中的其他原子和选择器,该字符串应该是唯一的。 default:atom的初始值。 atom 是存储状态的最小单位, 一种合理的设计是, atom 尽量小, 保持最大的灵活性。..., 当atom 改变时, 会触发重新计算。...相对于整个应用程序中的其他原子和选择器,该字符串应该是唯一的. get:作为对象传递的函数{ get },其中get是从其他案atom或selector检索值的函数。...get是从其他atom或selector检索值的函数。set是设置原子值的函数,其中第一个参数是原子名称,第二个参数是新值。

4K10

Facebook 新一代 React 状态管理库 Recoil

引入 Recoil Recoil 本身就是为了解决 React 全局数据流管理的问题,采用分散管理原子状态的设计模式。...Recoil 提出了一个新的状态管理单位 Atom,它是可更新和可订阅的,当一个 Atom 被更新时,每个被订阅的组件都会用新的值来重新渲染。...上面我们已经提到了 Atom 的概念, Atom 是一种新的状态,但是和传统的 state 不同,它可以被任何组件订阅,当一个 Atom 被更新时,每个被订阅的组件都会用新的值来重新渲染。...只需从选择器 get 回调中返回 Promise ,而不是返回值本身。...另外,其本身的分散管理原子状态的模式、读写分离、按需渲染、派生缓存等思想还是非常值得一学的。

1.9K10
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    前端框架_React知识点精讲

    当React开始「状态更新」时,它建立了一个所谓的workInProgress 树workInProgress Tree,反映了「未来」将被刷新到屏幕上的状态。...提供「优化内存使用」的机制 利用React「生命周期」来存储状态意味着更容易利用组件卸载时的「自动垃圾收集」。...对于状态管理库来说,如果在渲染过程中读取的值发生了变化,那么两个组件就有可能从外部存储中读取不同的值。...库 描述 React-Redux 利用特定选择器函数,「手动优化」 Recoil 通过订阅原子的「半手动方式」 Jotai 通过订阅原子的「半手动方式」 Zustand 利用特定选择器函数,「手动优化」...与大型单体存储相比,较小的独立存储的好处是,当所有订阅的组件卸载时,它们可以自动收集垃圾。而大型单体存储如果没有适当的内存管理,则更容易出现内存泄漏。

    1.8K10

    React-全局状态管理的群魔乱舞

    在实践中,当涉及到实际「状态存储」时,有两种主要方法。 ❝第一种是「由React自身维护」。...手动优化的一个例子是「通过选择器函数订阅一块存储的状态」。通过选择器读取状态的组件只有在该特定状态更新时才会重新渲染。 ❞ ❝第二种是为开发者「自动处理」,这样他们就不必考虑手动优化。...利用React「生命周期」来存储状态意味着更容易利用组件卸载时的「自动垃圾收集」。...库 描述 React-Redux 利用特定选择器函数,「手动优化」 Recoil 通过订阅原子的「半手动方式」 Jotai 通过订阅原子的「半手动方式」 Zustand 利用特定选择器函数,「手动优化」...与大型单体存储相比,较小的独立存储的好处是,当所有订阅的组件卸载时,它们可以自动收集垃圾。而大型单体存储如果没有适当的内存管理,则更容易出现内存泄漏。

    4.5K20

    Sentry 开发者贡献指南 - 前端(ReactJS生态)

    当您触发某些逻辑并且没有立即在您的断言逻辑中反映出来时,这可能会使您陷入一种虚假的安全感。...例如:以前你会做类似的事情 let x = volume || 0.5; 这是一个问题,因为 0 是 volume 的有效值,但因为它的计算结果为 false -y,我们不会使表达式短路,并且 x 的值为...https://github.com/getsentry/sentry/pull/15521 我们更喜欢使用可选链和空值合并而不是来自 lodash/get 的 get。...使用 context 当我们计划远离 Reflux 的路径时,useContext hook 提供了一个更简单的实现选项来共享状态和行为。...当您需要创建新的共享状态源时,请考虑使用 context 和 useContext 而不是 Reflux。此外,可以利用虫洞状态管理模式来公开共享状态和突变函数。

    8K30

    2023再谈前端状态管理

    为了避免状态传递过程中出现混乱,React 引入了“单向数据流”的理念。主要思想是组件不会改变接收的数据,只会监听数据的变化,当数据发生变化时他们会使用接收到的新值,而不是修改已有的值。...当组件的更新机制触发后,他们只是使用新值进行重新渲染。 父子组件通信可以直接使用 props 和回调方式;深层次、远距离组件则要通过“状态提升”和 props 层层传递。...缺点 Context 只能存储单一值,当数据量大起来时,你可能需要使用createContext创建大量context; 直接使用的话,会有一定的性能问题:每一次对state的某个值变更,都会导致其他使用该...Mobx的学习成本更低,没有全家桶。 Mobx在更新state中深层嵌套属性时更方便,直接赋值就好了,redux则需要更新所有途经层级的引用(当然搭配immer也不麻烦)。...基于ES6 proxy ,使用观察者/可观察模式的,当你修改一个值时,任何使用该值的组件都会自动重新渲染。 原子化管理状态,进行精确渲染。

    2.1K10

    React vs HTMX ,谁更适合你?

    HTMX 的理念是让事情变得简单,让开发者能在不丢弃熟悉的 HTML 的情况下,更深入多体验 Web 的魔力。 HTMX 作为一种流线型和灵活的选择,在由更复杂的前端框架主导的宇宙中,独树一帜。...当带有这些 HTMX 属性中的一个的 HTML 元素被触发,将会向给定的URL发出指定类型的 AJAX 请求。...get="/example" hx-params="*">你好 code秘密花园 非 GET 请求:当元素是 时,AJAX 请求的请求体会包含它所有输入的值,使用它们的...当元素不是 时,请求体将包含距离最近的 中所有输入的值。或者,如果元素有 value 属性,那么也会被添加到 Request Body 中。...如果要将其他元素的值添加到请求体中,可以使用 hx-include 属性,然后通过 CSS 选择器选择出你想要在请求体中包含的所有元素的值。

    2.4K21

    拥抱声明式状态管理的5个框架

    为了响应这种转变,许多框架已经出现或调整了其核心理念,以拥抱声明式状态管理和更简单的响应式模型。 声明式状态管理的兴起 声明式编程是一种范例,它强调描述程序应该完成什么,而不是它应该如何实现。...Solid 的响应式模型完全是声明式的,因为它依赖于信号——响应式原语,当它们的值发生变化时会自动触发更新。这消除了不必要的渲染,并在不影响简单性的前提下优化了性能。 4....Recoil:React 的原子状态模型 Recoil 是一个专门为 React 设计的现代状态管理库,提供了一种声明式和原子化的状态管理方法。...这种原子模型确保只有受影响的组件在状态更改时才会重新渲染,从而最大限度地减少不必要的更新。Recoil 的内置选择器进一步增强了状态派生,使其更容易以声明方式计算派生值。...当状态更改被清晰地定义并且响应式被自动处理时,开发人员可以更容易地跟踪数据在应用程序中的流动。这不仅加快了开发速度,还提高了代码库的整体质量。

    45210

    滴滴前端二面react面试题总结

    **当调用 setState时, React做的第一件事是将传递给setState的对象合并到组件的当前状态,这将启动一个称为和解( reconciliation)的过程。...componentWillReceiveProps:在初始化render的时候不会执行,它会在组件接受到新的状态(Props)时被触发,一般用于父组件状态更新时子组件的重新渲染shouldComponentUpdate...方法更新state,就会触发视图的重新渲染,完成表单组件的更新受控组件缺陷: 表单元素的值都是由React组件进行管理,当有多个输入框,或者多个这种组件时,如果想同时获取到全部的值就必须每个都要编写事件处理函数...因为非受控组件将真实数据储存在 DOM 节点中,所以在使用非受控组件时,有时候反而更容易同时集成 React 和非 React 代码。...而 vue 是通过对状态做代理,get 的时候收集以来,然后修改状态的时候就可以触发对应组件的 render 了。有的同学可能会问,为什么 react 不直接渲染对应组件呢?

    1.4K40

    152. 精读《recoil》

    然而 React Immutable 特性带来的可预测性非常利于调试和维护: 断点调试时变量的值与当前执行位置无关,已创建过的值不会突然 Mutable 突变,非常可预测。...在 React 框架下组件更新机制单一,只有引用变化才触发重渲染,而没有 Mutable 模式下 ForceUpdate 的心智负担。...2 简介 Recoil 解决 React 全局数据流管理的问题,采用分散管理原子状态的设计模式,支持派生数据与异步查询,在基本功能上可以覆盖 Redux。...Immutable 模式中,对数据流只有读与写两种诉求,而申明式编程讲究的是数据变化后 UI 自动 Rerender,那么对数据的读自然而然就被赋予了订阅其变化后触发 Rerender 的期待,但是写与读不同...派生的值必须严格缓存,并在命中缓存时引用保证严格相等。 原子存储的数据相互无关联,所有关联的数据都使用派生值方式推导。

    1.1K10

    最近几周react面试遇到的题总结

    而 React 的工作方式则不同。包含表单的组件将跟踪其状态中的输入值,并在每次回调函数(例如onChange)触发时重新渲染组件,因为状态被更新。...以这种方式由 React 控制其值的输入表单元素称为受控组件。...使用pureComponent的好处:当组件更新时,如果组件的props或者state都没有改变,render函数就不会触发。省去虚拟DOM的生成和对比过程,达到提升性能的目的。...而 vue 是通过对状态做代理,get 的时候收集以来,然后修改状态的时候就可以触发对应组件的 render 了。有的同学可能会问,为什么 react 不直接渲染对应组件呢?...对componentWillReceiveProps 的理解该方法当props发生变化时执行,初始化render时不执行,在这个回调函数里面,你可以根据属性的变化,通过调用this.setState()

    1.2K60

    如何整理自己的前端面试题库_2023-02-28

    当 ctrl+f5 强制刷新网页时,直接从服务器加载,跳过强缓存和协商缓存; 当 f5刷新网页时,跳过强缓存,但是会检查协商缓存; 强缓存 Expires(该字段是 http1.0 时的规范,值为一个绝对时间的...当 computed 的依赖状态发生改变时,就会通知这个惰性的 watcher,computed watcher 通过 this.dep.subs.length 判断有没有订阅者, 有的话,会重新计算,...(Vue 想确保不仅仅是计算属性依赖的值发生变化,而是当计算属性最终计算的值发生变化时才会触发渲染 watcher 重新渲染,本质上是一种优化。)...当使用后代选择器的时候,浏览器会遍历所有子元素来确定是否是指定的元素等等; (2)如果规则拥有ID选择器作为其关键选择器,则不要为规则增加标签。...然后再往上 组件update阶段同理 前面是react16以前的组建渲染方式。

    1.7K50

    2020最新前端面试题_2020年前端面试题

    当你修改了data的值然后马上获取这个dom元素的值, 是不能获取到更新后的值,你需要使用$nextTick这个回调, 让修改后的data值渲染更新到dom元素之后在获取,才能成功。...25、vue和jQuery的区别 jQuery是使用选择器($)选取DOM对象,对其进行赋值、取值、事件绑定等操作, 其实和原生的HTML的区别只在于可以更方便的选取和操作DOM对象, 而数据和界面是在一起的...当给对象新增不存在的属性,首先会把新的属性进行响应式跟踪 然后会触发对象 ob 的dep收集到的 watcher 去更新, 当修改数组索引时我们调用数组本身的 splice 方法去更新数组。...important > 内联样式 > ID选择器 > 类选择器 > (标签选择器、伪类选择器、属性选择器) 不同层级下: 正常来说权重值越高的优先级越高,但是一直以来没有具体的权重值划分,...需要管理焦点、选择文本或媒体播放时 触发式动画 与第三方 DOM 库集成 14、如何模块化 React 中的代码? 可以使用 export 和 import 属性来模块化代码。

    7.9K10

    《深度解构:React与Redux构建复杂表单的底层逻辑与实践》

    React与Redux的组合,通过组件化与状态管理的深度协同,为这类场景提供了一套严谨而灵活的解决方案,其核心价值不在于工具本身的堆砌,而在于如何通过架构设计将表单的复杂性拆解为可掌控的模块体系。...而通过Redux管理表单状态,能够实现数据与视图的解耦:表单的每个字段值、验证结果、交互状态(如是否被触碰、是否正在提交)被拆解为原子化状态,存储在Redux的状态树中。...React组件负责字段级的即时验证,当用户输入时触发验证函数,将结果同步至Redux状态;而涉及多字段关联的验证逻辑,则通过Redux中间件在状态更新后执行,确保所有关联字段的值就绪后再进行校验。...React的条件渲染与Redux的状态驱动相结合,能够优雅应对此类场景:Redux状态中存储表单的结构配置(如哪些字段显示、字段的排序与分组),当用户操作触发结构变更时,通过动作更新配置状态,React...当表单包含数百个字段时,每次输入导致的Redux状态更新可能引发不必要的组件重渲染,通过React的记忆化技术(如缓存组件与选择器函数),可以避免无关组件的重复渲染;Redux的状态规范化(将嵌套数据扁平化

    28310

    最新Web前端面试题精选大全及答案「建议收藏」

    )无法取消Promise,一旦新建它就会立即执行,无法中途取消 2)如果不设置回调函数,Promise内部抛出的错误,不会反映到外部 3)当处于pending(等待)状态时,无法得知目前进展到哪一个阶段...$route.params.name url展示上:params类似于post,query类似于get,也就是安全问题,params传值相对更安全点,query通过url传参,刷新页面还在,params...27.对vue 中keep-alive的理解 概念:keep-alive是vue的内置组件,当它动态包裹组件时,会缓存不活动的组件实例,它自身不会渲染成一个DOM元素也不会出现在父组件链中 作用:在组件切换过程中将状态保留在内存中...计算属性是用来声明式的描述一个值依赖了其他的值,当所依赖的值后者变量发生变化时,计算属性也跟着改变, Watch监听的是在data中定义的变量,当该变量变化时,会触发watch中的方法 41.mvvm框架是什么...React在调用setstate后,react会将传入的参数对象和组件当前的状态合并,触发调和过程, 在调和过程中,react会根据新的状态构建react元素树重新渲染整个UI界面,在得到元素树之后,react

    2.1K20

    react 学习笔记

    比如当我们的浏览器切换tab后,之前tab注册的 requestIdleCallback 触发的频率会变得很低 基于以上原因,React实现了功能更完备的 requestIdleCallbackpolyfill...当元素没有确定 id 的时候,万不得已你可以使用元素索引 index 作为 key 如果列表项目的顺序可能会变化,我们不建议使用索引来用作 key 值,因为这样做会导致性能变差,还可能引起组件状态的问题...如果你选择不指定显式的 key 值,那么 React 将默认使用索引用作为列表项目的 key 值。 元素的 key 只有放在就近的数组上下文中才有意义。...当我们生成两个不同的数组时,我们可以使用相同的 key 值 Post 组件可以读出 props.xx,但是不能读出 props.key (key的值应该使用其他属性名来传递) 受控组件 表单元素依赖于状态...受控组件,表单元素的修改会实时映射到状态值上,此时就可以对输入的内容进行校验. 受控组件只有继承React.Component才会有状态.

    1.8K20

    你必须知道的react redux 陷阱

    react redux介绍 React Redux 是 Redux 的官方 React UI 绑定层。它允许您的 React 组件从 Redux 存储中读取数据,并将操作分派到存储以更新状态。...简单来说,就是一个react官方支持的状态管理库。star数超2W,不可谓不火。但是今天要谈的不是他的优点和主流地位,而是谈使用它过程中可能遇到的陷阱。...接下来我,详细说一下,他们发生的条件: 陈旧props触发条件: 选择器函数依赖于该组件的 props 来提取数据 作为一个动作的结果,父组件会重新渲染并传递新的道具 但是这个组件的选择器函数在这个组件有机会用这些新道具重新渲染之前执行...“选择器函数”是接受 Redux 存储状态(或状态的一部分)作为参数并返回基于该状态的数据的任何函数。...当它根据 props 从 store 中读取一个值时,该数据不再存在,如果提取逻辑不小心,这可能会导致抛出错误。 嗯,其实我觉得这是一个使用方式的问题,这种bug可以说是设计之初就决定不能这样使用的。

    3.5K30

    前端二面react面试题整理

    参考 前端进阶面试题详细解答调和阶段 setState内部干了什么当调用 setState 时,React会做的第一件事情是将传递给 setState 的对象合并到组件的当前状态这将启动一个称为和解(reconciliation...componentWillReceiveProps:在初始化render的时候不会执行,它会在组件接受到新的状态(Props)时被触发,一般用于父组件状态更新时子组件的重新渲染shouldComponentUpdate...如果该属性的值是一个回调函数,它将接受底层的DOM元素或组件的已挂载实例作为其第一个参数。可以在组件中存储它。...状态管理react 是通过 setState 的 api 触发状态更新的,更新以后就重新渲染整个 vdom。...而 vue 是通过对状态做代理,get 的时候收集以来,然后修改状态的时候就可以触发对应组件的 render 了。有的同学可能会问,为什么 react 不直接渲染对应组件呢?

    1.5K20

    第八十六:前端即将或已经进入微件化时代

    每当组件第一次装载时,React将自动卸载和重新装载每个组件,并在第二次装载时恢复以前的状态。如果这打破了我们的应用程序,考虑移除严格的模式,直到我们可以修复组件以恢复现有状态的弹性。...如果更新是在离散的用户输入事件(如单击或按键事件)期间触发的,则React始终同步刷新效果函数。以前,这种行为并不总是可预测或一致的。 悬念树的一致性。...(悬念*我个人理解为尚未加载到界面中的内容)如果组件在完全添加到树之前挂起,React将不会在不完整状态下将其添加到树中,也不会激发其效果。...当树重新挂起并恢复为回退时,React现在将清除布局效果,然后在边界内的内容再次显示时重新创建它们。这解决了一个问题,即当与未加载的组件一起使用时,组件库无法正确测量布局。 新的JS环境要求。...此警告是为订阅添加的,但人们主要在设置状态良好的情况下遇到它,而解决方法会使代码变得更糟。 不抑制控制台日志。当我们使用严格模式时,React会对每个组件渲染两次,以帮助我们发现意外的副作用。

    4K10
    领券