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

换回自己的,就可以了!

相关推荐
chilavert31815 小时前
技术演进中的开发沉思-228 Ajax: Aptana开发
前端·javascript·ajax
kwg12615 小时前
Dify二次开发-AI 应用端反馈指令接收(AI 应用端 → Dify)
前端·数据库·人工智能
哟哟耶耶15 小时前
knowledge-scss学习
前端·学习·scss
丫丫72373415 小时前
Three.js 材质系统总结笔记
javascript·笔记·材质
坚定信念,勇往无前15 小时前
springboot +mongodb游标分页,性能好。前端存储游标历史
前端·spring boot·mongodb
GIS遥遥15 小时前
2025Cesium进阶教程(5)| webgis智慧城市开发,大屏可视化行政区高亮
javascript·cesium·gis开发·三维gis·webgis开发
却话巴山夜雨时i15 小时前
295. 数据流的中位数【困难】
java·服务器·前端
云技纵横15 小时前
Vue无限滚动实战——从原理到企业级优化方案
前端
细心细心再细心15 小时前
响应式记录
前端·vue.js
北辰alk16 小时前
Vue打包后静态资源图片失效?一网打尽所有解决方案!
vue.js