mobx 的autorun和reaction使用,监听mobx值变化

mobx 的autorun和使用:

Mobx中的衍生----动作(autorun、reaction)

(1)autorun

当你想创建一个永远不会被观察的响应式函数时,可以使用autorun。
当autorun依赖的状态变化时会自动执行参数的function,返回值disposer是autorun的清除函数,当不再需要autorun时,可以调用disposer清除autorun。

autorun参数中的函数在使用autorun时会立即执行一次,然后在每次它依赖的state发生变化时自动执行一次。

注意:

  • autorun不会产生新值,是基于执行函数产生效果
  • autorun不会被观察,是反应式代码桥接到命令式代码的方式
  • 可用于打印日志、更新UI的代码、发起请求
  • autorun第一个参数是函数,可接受第二个参数,处理delay、name、error等
  // autorun写法
  disposer = autorun(() => {
    if (store.refresh.bool) {
      console.log('监听', store.refresh.bool);
    } else {
      this.onResetCondition()
      console.log('监听2', store.refresh.bool);
    }
  });

(2)reaction

reaction是autorun的变种,第一个参数为数据函数,第二个参数为效果函数,数据函数返回一个值,作为效果函数的参数,效果函数不会对依赖的状态作出反应,只有数据函数返回的值变化时才会执行。

注意:
1、
有时候reaction无法监听到数据的变化,原因:

当前页面被销毁了,仓库也跟着被销毁,例如:

使用----windows.location.href="/url" 当前页面-打开URL页面
它们会重定向到指定的页面


 window.location.href = '/';
 

解决方法,使用this.props.history.push进行路由跳转,等等


 this.props.history.push('/')
 

2、

  • reaction 返回一个清理函数,不需要再执行时应该调用清理函数
  • 数据函数对state的改变作出反应
  • 效果函数仅对数据函数中访问的数据作出反应,不对state的改变作出反应
  • autorun第一个参数是函数,可接受第二个参数,处理delay、name、error等
   componentWillUnmount() {
    // 销毁时清除reaction
    this.reaction();
  }
  // reaction写法
  reaction = reaction(
    () => store.refresh.bool,
    (data) => {
      console.log(data)
      }
    }
  );

推荐


  • 1
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
监听 localStorage 变化,可以使用`window.addEventListener('storage', callback)`方法。这个方法会在 localStorage 中发生变化时触发回调函数。 在 MobX 中,可以使用`autorun`函数来监听 localStorage 的变化。`autorun`函数会自动追踪被观察的数据,并在它们发生变化时执行回调函数。 以下是一个使用 MobX 监听 localStorage 的例子: ```javascript import { autorun } from 'mobx'; // 定义一个 observable 对象 const storage = { value: localStorage.getItem('value') || '', setValue(newValue) { this.value = newValue; localStorage.setItem('value', newValue); }, }; // 使用 autorun 监听 storage.value 的变化 autorun(() => { console.log(`localStorage 中的 value 发生变化:${storage.value}`); }); // 修改 localStorage 中的 value storage.setValue('new value'); ``` 在这个例子中,我们先定义了一个 observable 对象 `storage`,它有一个属性 `value` 表示 localStorage 中的。`setValue` 方法用于修改 `value` ,并将修改后的存储到 localStorage 中。 然后我们使用 `autorun` 函数来监听 `storage.value` 的变化。当 `storage.value` 发生变化时,`autorun` 函数会自动执行回调函数,输出变化后的。 最后我们调用 `storage.setValue('new value')` 修改了 localStorage 中的 value ,这时 `autorun` 函数会自动执行回调函数,输出新的。 注意:`autorun` 函数会在组件挂载时自动执行一次回调函数,因此在上面的例子中,在控制台中会先输出 localStorage 中的 value

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值