当前位置: 首页 > news >正文

vue3源码(3)——computed

Vue3中的computed底层源码主要是通过使用Proxy对象来实现的。下面是对Vue3中computed底层源码的详细解读:

  1. 在Vue3中,computed的实现是通过使用createComputed函数来创建的。createComputed函数接收两个参数:getter和setter。

  2. 在createComputed函数中,首先会创建一个响应式的Ref对象,用于存储computed的值。

  3. 接着,会创建一个ReactiveEffect对象,用于存储computed的getter函数。ReactiveEffect对象中包含了一个deps数组,用于存储computed所依赖的响应式数据。

  4. 在ReactiveEffect对象中,会调用getter函数,并在getter函数中使用track函数来收集computed所依赖的响应式数据。

  5. 在getter函数中,会调用runInEffect函数来执行getter函数,并在执行过程中使用track函数来收集computed所依赖的响应式数据。

  6. 在runInEffect函数中,会调用getter函数,并在执行过程中使用track函数来收集computed所依赖的响应式数据。

  7. 在getter函数执行完毕后,会调用cleanup函数来清除deps数组中的无效依赖。

  8. 在createComputed函数中,会返回一个Proxy对象,用于代理computed的访问。Proxy对象中的get函数会调用ReactiveEffect对象中的run函数来执行getter函数,并在执行过程中使用track函数来收集computed所依赖的响应式数据。

  9. 在Proxy对象中的set函数中,会调用ReactiveEffect对象中的invalidate函数来标记computed的值为无效,并在执行过程中使用trigger函数来触发computed所依赖的响应式数据的更新。

总的来说,Vue3中的computed底层源码主要是通过使用Proxy对象、Ref对象、ReactiveEffect对象、track函数、trigger函数等来实现的。这些对象和函数的组合,使得computed能够实现响应式的计算,并在计算过程中自动收集和更新依赖的响应式数据。

http://www.lryc.cn/news/62408.html

相关文章:

  • 数学建模第七天:数学建模算法篇之插值及MATLAB实现
  • RUST 每日一省:生命周期作用域
  • 【过程8】——能量守恒视角总结感受
  • kong(4):限流配置
  • 人脸识别 Face Recognition 入门
  • 【AI绘画】Midjourney的使用及程序示例
  • 无公网IP?教你在外远程访问本地wamp服务器「内网穿透」
  • leetcode 628. 三个数的最大乘积
  • fork函数如何创建进程,exit/_exit函数如何使进程终止的详细分析与代码实现
  • 重置电脑时提示“缺少所需的驱动器分区”怎么办?
  • 在KylinV10安装Dm8
  • 「SQL面试题库」 No_46 交换工资
  • SLAM论文速递【SLAM—— RDS-SLAM:基于语义分割方法的实时动态SLAM—4.24(1)
  • OJ练习第82题——填充书架
  • OHOS IDE和SDK的安装方法
  • New Year Garland(计数类DP)
  • 32岁阿里P7,把简历改成不知名小公司,学历改成普通本科,工作内容不变,投简历全挂!...
  • 从三室心脏MRI影像检测主动脉瓣病变
  • 【JavaWeb】JavaScript
  • Apache Doris 1.2.4 Release 版本正式发布|版本通告
  • 【C++STL】map
  • vue2项目PC端如何适配不同分辨率屏幕
  • CorelDRAW2023最新版本图像设计软件
  • 第64章 树型结构数据的前端渲染渲染显示示例
  • 超级国际象棋:第二个里程碑已完成
  • vue3 HTML 和静态资源
  • 5G基站外市电改造建设方案 (ppt可编辑)
  • C++ 类和对象(上)
  • 【BIM+GIS】BIM模型导入GIS软件之前的一些处理设置
  • js FileReader的常用使用方法