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

换回自己的,就可以了!

相关推荐
嘉琪0011 分钟前
vue3+ts面试题(一)JSX,SFC
前端·javascript·react.js
何贤14 分钟前
🪐 行星科技概念官网!Hero Section 回归!(Three.js ✨)
前端·javascript·three.js
前端拿破轮17 分钟前
ReactNative从入门到性能优化(一)
前端·react native·客户端
码界奇点27 分钟前
Java Web学习 第1篇前端基石HTML 入门与核心概念解析
java·前端·学习·xhtml
云枫晖33 分钟前
Webpack系列-开发环境
前端·webpack
Rverdoser38 分钟前
制作网站的价格一般由什么组成
前端·git·github
拉不动的猪38 分钟前
深入理解 JavaScript 中的静态属性、原型属性与实例属性
前端·javascript·面试
linda26181 小时前
链接形式与跳转逻辑总览
前端·javascript
怪可爱的地球人1 小时前
骨架屏
前端
用户677847150621 小时前
前端将html导出为word文件
前端