Vue的computed大致细节

computed

computed

具体实现流程

  1. computer内部首先是标准化参数
  2. 然后调用runner函数进行依赖收集
  3. 设置dirty为true
  4. 创建副作用函数,具体如下
js 复制代码
const runner = effect(getter,{
    //延迟执行
    lazy:true,
    //标记为computed effect 用于咋trigger阶段的优先级排序
    computed:true,
    //调度执行实现
    scheduler:() => {
        //如果dirty为true,则执行副作用函数
        if(dirty){
            //设置dirty为false
            dirty = false
            trigger(computed,"set",'value')
        }
    }
})
  1. 创建computed对象,具体如下
js 复制代码
computed = {
    _v_isRef:true,
    effect:runner,
    get value(){
        if(dirty){
            value = runner()
            dirty = false
        }
        track(computed,"get",'value')
        return value
    }
    set value(newValue){
        setter(newValue)
    }
}

//最后
return computed

相关介绍

  • dirty默认是false,当依赖发送变化是会设置dirty为true,然后下一次执行get时会重新计算并设置dirty为false,得到新的value
  • dirty为false为,直接返回value
  • dirty为true时,会重新计算value并设置dirty为false,然后返回value

当computed被访问时会触发get

computer的执行顺序

runner大于普通effect函数

例题

javascript 复制代码
import {effect } from '@vue/reactivity'
import {ref,computed} from 'vue'

const count = ref(0)
const plusOne = computed(() => count.value +1)

effect(() => {
    console.log(cont.value+plusOne.value)
})

function increment() {
    count.value++
}

increment() 

输出结果 : 1 3 3

主要原因时执行优先级不同,输出1就不解释了。先执行pluseOne的runner,将plusOne的runner的dirty设置为true,然后通知他的依赖effect,这时由于plusOne的dirty为true,所以会再次执行pluseOne的get拿到新值2,再加上1就得到了3,同时也会设置dirty为false,然后再次执行count普通effect依赖, 由于dirty为false再次输出3

相关推荐
优联前端17 分钟前
uni-app-通过vue-cli命令行快速上手
开发语言·前端·vue.js·uni-app·优联前端
点燃银河尽头的篝火(●'◡'●)1 小时前
【BurpSuite】Cross-site scripting (XSS 学徒部分:1-9)
前端·web安全·网络安全·xss
Jiaberrr2 小时前
手把手教你:微信小程序实现语音留言功能
前端·微信小程序·小程序·语音·录音
熊猫在哪2 小时前
安装nuxt3
前端·nuxt.js
安冬的码畜日常2 小时前
【CSS in Depth 2 精译_036】5.6 Grid 网格布局中与对齐相关的属性 + 5.7本章小结
前端·css·css3·html5·网格布局·grid·css网格
啧不应该啊3 小时前
vue配置axios
前端·javascript·vue.js
__fuys__3 小时前
【HTML样式】加载动画专题 每周更新
前端·javascript·html
Want5953 小时前
HTML粉色烟花秀
前端·css·html
让开,我要吃人了3 小时前
HarmonyOS鸿蒙开发实战(5.0)自定义全局弹窗实践
前端·华为·移动开发·harmonyos·鸿蒙·鸿蒙系统·鸿蒙开发
yanlele4 小时前
前端面试第 66 期 - Vue 专题第二篇 - 2024.09.22 更新前端面试问题总结(20道题)
前端·javascript·面试