watchEffect的简易版 - 源码系列8

写 watchEffect了,这个真真算容易了!

目标 watchEffect

首先看下,目标 watchEffect 的功能:

js 复制代码
import {
  reactive,
  effect,
  watch,
  watchEffect,
} from '../../../node_modules/@vue/runtime-dom/dist/runtime-dom.esm-browser.js';
// import { reactive, effect,watch } from './reactivity.js';
const obj = reactive({
  name: 'hua',
  age: 4,
});
// 默认是异步,这边暂时只实现同步
watchEffect(
  () => {
    console.log(obj.name);
  },
  { flush: 'sync' }
);
obj.name = 'hua changed';

没有加配置的 watchEfect,默认是异步执行的,这里先将其设置为同步,异步之后再写。

分析 watchEffect

  • watchEffect 是一个函数,可以有 2 个参数
  • 第一个参数,是回调函数
  • 第二个参数,是配置项,暂时不管

最重点的是,这个和 effect 走起来基本一模一样啊!所以,嗯!

写 watchEffect

reactivity/src/apiWatch下:

js 复制代码
export function watchEffect(cb) {
  const _effect = new ReactiveEffect(cb, null);
  _effect.run();
}

换回自己的,就可以了!

相关推荐
0思必得07 分钟前
[Web自动化] Selenium元素定位
前端·python·selenium·自动化·html
EEEzhenliang34 分钟前
CSS知识概括、总结
前端·css
大阳光男孩1 小时前
ElementUI表格懒加载子级更新数据刷新不生效问题
前端·javascript·elementui
wy3136228211 小时前
C#——意框架(结构说明)
前端·javascript·c#
研☆香1 小时前
JS中的三种显示弹窗
开发语言·前端·javascript
俩毛豆1 小时前
HarmonyOS APP开发-一文讲清使用Web组件加载网页的三种方法-《精通HarmonyOS NEXT :鸿蒙App开发入门与项目化实战》读者福利
前端·华为·harmonyos
猛扇赵四那边好嘴.1 小时前
Flutter 框架跨平台鸿蒙开发 - 问答社区应用开发教程
开发语言·javascript·flutter·华为·harmonyos
C_心欲无痕1 小时前
Next.js 路由系统对比:Pages Router vs App Router
开发语言·前端·javascript
LawrenceLan1 小时前
Flutter 零基础入门(二十二):Text 文本组件与样式系统
开发语言·前端·flutter·dart
hxjhnct1 小时前
JavaScript 的 new会发生什么
开发语言·javascript