[聚合文章] MobX入门

JavaScript 1900-01-01 20 阅读

本文尝试解释MobX是如何运作的。我们将用MobX创建一个小案例。如果你正在找靠谱的MobX文档,可以去看官方文档

什么是MobX

官方文档的解释:简洁,易扩展的状态管理。简单来说,MobX可以很好的管理应用程序的状态/数据,同时又简洁,易扩展。先来看一张图:

mobx-diagram

我们通过上图的的步骤来创建一个简单应用。

State

mobx-store

在MobX中你可以设置一个或者多个state,我们先设置一个:

var store = mobx.observable({    counter: 0})

我们初始化store,只有一个状态数据counter。你的对象可能有多个层级对应多个不同的属性。

Rendering

mobx-render

MobX.js一起用效果很好,但是不用react.js也可以。我们用原生JavaScript来把状态渲染到页面:

`<div>-</div>`
function render(state) {    document.getElementById('counter').textContent = state.counter;}

我们拿到了状态并更新到了页面。

Actions

mobx-action

当action发生,我们可以直接改变状态:

&lt;button id="button"&gt;Increment&lt;/button&gt;
document.getElementById('button').addEventListener('click', function() {    store.counter = store.counter + 1})

当我们点击按钮,state 中的 counter将会加1。

改变State

当我们改变状态,我们将更新渲染:

mobx.observe(store, function() {    render(store)})

最终代码

jsfiddle

<div>-</div>&lt;button id="button"&gt;Increment&lt;/button&gt;
// JavaScriptvar store = mobx.observable({    counter: 0})function render(state) {    document.getElementById('counter').textContent = state.counter;}document.getElementById('button').addEventListener('click', function() {    store.counter = store.counter + 1})mobx.observe(store, function() {    render(store)})

与Redux比较

比起Redux,MobX不管是写代码还是理解,似乎都要简单很多,而且你不用写很多重复的代码。但是随之而来的代价就是你不知道它内部是如何运作的。MobX也可以写的和Redux一样:用actions,创建action,创建异步action等等,但是不是强制的。总的来说,如果你保持你的代码模块化,可测试以及数据单向流,MobX是个不错的选择。

> 原文:https://bumbu.github.io/simple-mobx/

注:本文内容来自互联网,旨在为开发者提供分享、交流的平台。如有涉及文章版权等事宜,请你联系站长进行处理。