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();
}

换回自己的,就可以了!

相关推荐
漂流瓶jz5 小时前
总结CSS组件化演进之路:命名规范/CSS Modules/CSS in JS/原子化CSS
前端·javascript·css
踩着两条虫5 小时前
「AI + 低代码」的可视化设计器
开发语言·前端·低代码·设计模式·架构
Jagger_5 小时前
项目上线忙碌结束之后,为什么总想找点事做?
前端
GalenZhang8886 小时前
OpenClaw 配置多个飞书账号实战指南
前端·chrome·飞书·openclaw
steven~~~6 小时前
为什么mq报错
javascript
萌新小码农‍7 小时前
python装饰器
开发语言·前端·python
threelab7 小时前
Three.js 初中数学函数可视化 | 三维可视化 / AI 提示词
开发语言·前端·javascript·人工智能·3d·着色器
爱学习的程序媛8 小时前
浏览器工作原理全景解析
前端·浏览器·web
凉辰8 小时前
解决 H5 键盘遮挡与页面上推
开发语言·javascript·计算机外设
我是若尘9 小时前
用 Git Worktree 同时开多个需求,不用来回 stash
前端