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

换回自己的,就可以了!

相关推荐
SuperEugene1 分钟前
前端空值处理规范:Vue 实战避坑,可选链、?? 兜底写法|项目规范篇
前端·javascript·vue.js
前端百草阁2 分钟前
Vue3 Diff 算法详解
前端·javascript·vue.js·算法·前端框架
im_AMBER3 分钟前
前后端对接: ESM配置与React Router
前端·javascript·学习·react.js·性能优化·前端框架·ecmascript
学且思5 分钟前
使用import.meta.url实现传递路径动态加载资源
前端·javascript·vue.js
problc7 分钟前
OpenClaw 的前端用的React还是Vue?
前端·vue.js·react.js
凰轮10 分钟前
vue实现大文件切片上传
vue.js
冰暮流星10 分钟前
javascript里面的return语句讲解
开发语言·前端·javascript
步步为营DotNet14 分钟前
使用.NET 11的Native AOT提升应用性能
java·前端·.net
Never_Satisfied15 分钟前
在JavaScript / HTML中,监听鼠标滚动事件
javascript·html·计算机外设
左耳咚17 分钟前
Claude Code 记忆系统与 CLAUDE.md
前端·人工智能·claude