新手php网站建设,旧家电回收网站开发,动易网站首页制作,西安搜索引擎营销推广公司对于React而言#xff0c;大家熟能而详的是redux#xff0c;但我们的项目用的是mobx#xff0c;接下来就让我给你详细说下它的优势和不足#xff0c;可以参考。
MobX是什么#xff1f;
MobX 是一种简单易用的状态管理库#xff0c;它采用基于观察者的模式#xff0c;可…对于React而言大家熟能而详的是redux但我们的项目用的是mobx接下来就让我给你详细说下它的优势和不足可以参考。
MobX是什么
MobX 是一种简单易用的状态管理库它采用基于观察者的模式可以说Mox是面向对象的自动跟踪应用程序中的变化。相比之下Redux 是一个更复杂的库它采用基于 Flux 的模式通过一个单一的 store 来管理整个应用程序的状态。 在 MobX 中状态是以变量的形式存在的可以说Mox是面向对象的这些变量可以被观察者追踪。当状态发生变化时MobX 会自动更新相关的视图。这使得 MobX 非常适合快速开发因为它可以减少大量的手动更新代码。此外MobX 还提供了一些高级功能如支持并发更新和自动收集 side effects。
Mobx与redux对比
1.Redux的编程范式是函数式的而Mox是面向对象的
2.因此数据上来说Redux理想的是immutable( immutable对象是不可直接赋值的对象,它可以有效的避免错误赋值的问题)每次都返回一个新的数据而Mobx从始至终都是一份引用。因此Redux是支持数据回溯的
3.然而和Redux相比使用mobx的组件可以做到精准更新这一点得益于Mobx的observable对应的Redux是用dispath进行广播通过Provider和connect来比对前后差别控制更新粒度Mobx更加精细MobX背后的哲学很简单:任何源自应用状态的东西都应该自动地获得。
相对于react来说mobx没有一个全局的状态树状态分散在各个独立的store中。mobx的工作原理非常简单使用Object.defineProperty来拦截对数据的访问一旦值发生变化将会调用react的render方法来实现重新渲染视图的功能或者触发autorun等。Mobx的核心原理是通过action触发state的变化进而触发state的衍生对象computed value Reactions