首页 > 其他分享 >mobx

mobx

时间:2023-05-29 14:55:09浏览次数:27  
标签:reaction console log observable mobx autorun 副作用

MobX 是一个用于状态管理的 JavaScript 库,它提供了简单而强大的状态管理机制,使得在应用程序中跟踪和更新状态变得更加容易和高效。

MobX 的核心概念是可观察状态(Observable State)和衍生(Derived)。可观察状态是应用程序中的数据源,它们可以被观察和订阅。衍生是从可观察状态中派生出来的数据,它们会自动地根据可观察状态的变化进行更新。

在 MobX 中,可以使用 observable 函数将对象或属性标记为可观察的,以便跟踪其变化。可以使用 computed 函数定义衍生属性,它会自动更新其值,当其依赖的可观察状态发生变化时。通过使用 action 函数,可以定义操作(或称为动作),它们会修改可观察状态。

MobX 还提供了一种称为反应(Reaction)的机制,它允许在可观察状态变化时自动执行副作用,例如更新用户界面或触发网络请求。

以下是一个使用 MobX 的简单示例:

 



import { observable, computed, action } from 'mobx';

class CounterStore {
  @observable count = 0;

  @computed get doubledCount() {
    return this.count * 2;
  }

  @action increment() {
    this.count++;
  }

  @action decrement() {
    this.count--;
  }
}

const counterStore = new CounterStore();

console.log(counterStore.count); // 输出: 0

counterStore.increment();
console.log(counterStore.count); // 输出: 1

console.log(counterStore.doubledCount); // 输出: 2

counterStore.decrement();
console.log(counterStore.count); // 输出: 0
如果在上面的示例中去掉 @computed,计算属性将变为普通的方法,不再具有自动计算和更新的功能
比如改成这样
console.log('Total Items:', cart.totalItems()); // 输出:
2 console.log('Total Price:', cart.totalPrice()); // 输出: 2.98

 

 

 

 

autorun 函数来创建一个自动运行的反应,它会在 todos 状态发生变化时自动执行
import { observable, action, autorun } from 'mobx';

class TodoStore {
  @observable todos = [];

  @action addTodo = (title) => {
    this.todos.push({ title, completed: false });
  };

  @action completeTodo = (index) => {
    this.todos[index].completed = true;
  };
}

const todoStore = new TodoStore();

autorun(() => {
  console.log('Todos:', todoStore.todos);
});

todoStore.addTodo('Buy groceries');
todoStore.addTodo('Clean the house');
todoStore.completeTodo(0);

 

 

以下是一个示例代码,展示了在 MobX 中如何使用 reactionautorun 自动执行副作用:

import { observable, reaction, autorun } from 'mobx';

class User {
  @observable name = '';
  @observable age = 0;
}

const user = new User();

// 使用 reaction 自动执行副作用
const reactionDisposer = reaction(
  () => user.name,
  (name) => {
    console.log(`Name changed: ${name}`);
  }
);

// 使用 autorun 自动执行副作用
const autorunDisposer = autorun(() => {
  console.log(`Age changed: ${user.age}`);
});

// 修改观察的属性,自动执行副作用
user.name = 'John'; // 输出: Name changed: John
user.age = 25; // 输出: Age changed: 25

// 停止 reaction 和 autorun 的副作用
reactionDisposer();
autorunDisposer();

 

在这个示例中,我们创建了一个 User 类,其中包含可观察的属性 nameage。然后我们使用 reactionautorun 来定义副作用函数。

reaction 接受一个数据源和一个副作用函数。当数据源发生变化时,副作用函数将自动执行。在示例中,我们监听 user.name 的变化,并在变化时打印出新的名字。

autorun 接受一个副作用函数,它将自动执行并追踪函数内部使用的任何可观察数据。在示例中,我们追踪 user.age 的变化,并在变化时打印出新的年龄。

最后,我们修改了观察的属性,触发了副作用函数的自动执行。通过停止 reactionautorun 的副作用函数,我们可以手动停止它们的自动执行。

通过使用 reactionautorun,我们可以方便地自动执行副作用,无需手动编写订阅和通知的代码。

希望这个示例对你有帮助。如果还有其他问题,请随时提问。

   

标签:reaction,console,log,observable,mobx,autorun,副作用
From: https://www.cnblogs.com/nafio/p/17440423.html

相关文章

  • mobxtem 使用的过程中突然 只能下载 不能上传
    问题: 昨天moba使用的还好好的。今天就只能下载不能上传了。解决: 我只是用了一个 ssh 的协议。只需要设置一下moba就可以了。截图如下:  首先将打开的终端全部关闭,然后,重新打开一个。 ......
  • mobx store 创建区别
    mobx6之前的版本创建store的时候,如果有observable属性,那么store自动变成observable的mobx6之后的版本需要自己在构造函数调用makeObservable函数并传入store本身,从而把......
  • Mobx
    Mobx解决的问题React的数据管理,除了redux之外,一个新的状态管理方案mobx传统React使用的数据管理库为Redux。Redux要解决的问题是统一数据流,数据流完全可控并可追踪。要......
  • 认识一下 Mobx
    我们是袋鼠云数栈UED团队,致力于打造优秀的一站式数据中台产品。我们始终保持工匠精神,探索前端道路,为社区积累并传播经验价值。本文作者:霜序(掘金)前言在之前的文......
  • 2021-12-14 MobX分享
    MobX分享 文档地址:https://cn.mobx.js.org/ MobX是一种简单的、可扩展的状态管理,它通过透明的函数响应式编程使得状态管理变得简单和可扩展。 React通过提供机制......
  • 【MobX】390- MobX 入门教程(上)
    点击上方“前端自习课”关注,学习起来~本文考虑到篇幅问题,将《MobX入门教程》分成上、下两篇文章,方便阅读。分配安排:一、MobX介绍首先看下官网介绍:★MobX是一个经过战火......
  • react react-router-dom6 mobx6整理
    reactreact-router-domv6route/index.jsimportReact,{Suspense,lazy}from'react'importLayoutfrom'../views/Layout/index'constHome=lazy(()=>......
  • mobx在react中的使用
    mobx在react中的使用步骤安装依赖包[email protected]@5.13.0#[email protected]@5.13.0核心api定义可观察数据假设声明可观察数据的文......