vue2与vue3响应原理

简介: 之前的vue2、现在的vue3,它都是vue。为什么要出vue3?肯定是因为vue3存在一定性的优势啊。本文就响应式原理进行分析。

之前的vue2、现在的vue3,它都是vue。为什么要出vue3?肯定是因为vue3存在一定性的优势啊。

本文就响应式原理进行分析。


两者基本都是发布订阅模式。通俗一点就是数据发生变化就要触发依赖,更新数据。

vue2响应原理


vue2主要是通过类new一个实例来实现的,通过object.defineProperty()来劫持各个属性的getset


Object.defineProperty(obj, key, {
            enumerable: true,//可枚举性,表示能否通过for-in遍历得到属性。默认值为true。
            configurable: false,//可配置性,控制着其描述的属性的修改,表示能否修改属性的特性,能否把属性修改为访问器属性,或者能否通过delete删除属性从而重新定义属性。默认值为true。
            get() {
                //初始化
                //订阅者数据变化时,往Dep中添加观察者
                Dep.target && dep.addSub(Dep.target);
                return value;
            },
            set: (newValue) => {
                this.observer(newValue);
                if (newValue !== value) {
                    value = newValue;
                }
                //告诉Dep通知变化
                dep.notify();
            }
        })


获取数据展示


首先Observer实例化,拿到数据。遍历数据属性,defineProperty劫持每个属性。通过defineProperty的get来获取属性。get中除了要获取属性外,还需要做一个添加依赖的动作,为数据更新行为做准备(即dep.addSub(Dep.target)


Dep 收集依赖

使用Dep类实现依赖的收集器。收集依赖后,可以实现数据改变驱动页面更新等操作。内部存在添加依赖、触发依赖两个方法。

Dep中先创建一个空数组,存放要收集的依赖。addSub添加依赖则是将收集到的watcher放进数组中;notify触发依赖则是通知watcher去更新,而不是自己更新。


class Dep {
    constructor() {
        this.subs = [];
    }
    addSub(watcher) {
        this.subs.push(watcher);
    }
    notify() {
        this.subs.forEach(item => item.update())
    }
}


Watcher


主要存在两个功能:获取值、更新值。 获取值中牵扯到编译,需要从html中匹配绑定的变量,在此将省略。 更新值的核心就是将新值赋值给旧值。


class Watcher {
    constructor(vm, expr, cb) {
        this.vm = vm;
        this.expr = expr;
        this.cb = cb;
        this.oldVal = this.getOldVal();
    }
    getOldVal() {
        Dep.target = this;
        const oldVal = compileUtil.getVal(this.expr, this.vm);
        Dep.target = null; // compileUtill类主要功能是编译,getVal获取变量值
        return oldVal;
    }
    update() {
        const newVal = compileUtil.getVal(this.expr, this.vm);
        if (newVal !== this.oldVal) {
            this.cb(newVal);
        }
    }
}


更新数据展示


更新触发defineProperty的set,将新值传给observer,在通知dep去更新。notify中通过调用watcher的update操作,重新设置新值。


vue3响应原理


在vue3中,使用Proxy获取和设置值。主要核心是收集依赖和触发依赖。

reactive为例:

在笔记中我也提到reactive本质:


let obj = { name: 'dy', age: 18 };
let state = new Proxy(obj, {
    get(obj, key) {
        console.log(obj, key); // { name: 'dy', age: 18 } name
        return Reflect.get(obj, key);
    },
    set(obj, key, value) {
        const result = Reflect.set(obj, key, value);
        return result;
    }
});


上述代码中讲述了proxy是如何获取以及设置值的。

在其中,get时收集依赖,set触发依赖,与vue2类似。


作者:ClyingDeng

链接:https://juejin.cn/post/6935686232768774180

来源:稀土掘金

著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

目录
打赏
0
0
0
0
0
分享
相关文章
vue2和vue3的响应式原理有何不同?
大家好,我是V哥。本文详细对比了Vue 2与Vue 3的响应式原理:Vue 2基于`Object.defineProperty()`,适合小型项目但存在性能瓶颈;Vue 3采用`Proxy`,大幅优化初始化、更新性能及内存占用,更高效稳定。此外,我建议前端开发者关注鸿蒙趋势,2025年将是国产化替代关键期,推荐《鸿蒙 HarmonyOS 开发之路》卷1助你入行。老项目用Vue 2?不妨升级到Vue 3,提升用户体验!关注V哥爱编程,全栈开发轻松上手。
管理数据必备;侦听器watch用法详解,vue2与vue3中watch的变化与差异
一篇文章同时搞定Vue2和Vue3的侦听器,是不是很棒?不要忘了Vue3中多了一个可选项watchEffect噢。 博客不应该只有代码和解决方案,重点应该在于给出解决方案的同时分享思维模式,只有思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
Vue Router 核心原理
Vue Router 是 Vue.js 的官方路由管理器,用于实现单页面应用(SPA)的路由功能。其核心原理包括路由配置、监听浏览器事件和组件渲染等。通过定义路径与组件的映射关系,Vue Router 将用户访问的路径与对应的组件关联,支持哈希和历史模式监听 URL 变化,确保页面导航时正确渲染组件。
|
3月前
|
vue使用iconfont图标
vue使用iconfont图标
177 1
极致的灵活度满足工程美学:用Vue Flow绘制一个完美流程图
本文介绍了使用 Vue Flow 绘制流程图的方法与技巧。Vue Flow 是一个灵活强大的工具,适合自定义复杂的流程图。文章从环境要求(Node.js v20+ 和 Vue 3.3+)、基础入门案例、自定义功能(节点与连线的定制、事件处理)到实际案例全面解析其用法。重点强调了 Vue Flow 的高度灵活性,虽然预定义内容较少,但提供了丰富的 API 支持深度定制。同时,文中还分享了关于句柄(handles)的使用方法,以及如何解决官网复杂案例无法运行的问题。最后通过对比 mermaid,总结 Vue Flow 更适合需要高度自定义和复杂需求的场景,并附带多个相关技术博客链接供进一步学习。
属性描述符初探——Vue实现数据劫持的基础
属性描述符还有很多内容可以挖掘,比如defineProperty与Proxy的区别,比如vue2与vue3实现数据劫持的方式有什么不同,实现效果有哪些差异等,这篇博文只是入门,以后有时间再深挖。 博客不应该只有代码和解决方案,重点应该在于给出解决方案的同时分享思维模式,只有思维才能可持续地解决问题,只有思维才是真正值得学习和分享的核心要素。如果这篇博客能给您带来一点帮助,麻烦您点个赞支持一下,还可以收藏起来以备不时之需,有疑问和错误欢迎在评论区指出~
ry-vue-flowable-xg:震撼来袭!这款基于 Vue 和 Flowable 的企业级工程项目管理项目,你绝不能错过
基于 Vue 和 Flowable 的企业级工程项目管理平台,免费开源且高度定制化。它覆盖投标管理、进度控制、财务核算等全流程需求,提供流程设计、部署、监控和任务管理等功能,适用于企业办公、生产制造、金融服务等多个场景,助力企业提升效率与竞争力。
126 12
Vue中的class和style绑定
在 Vue 中,class 和 style 绑定是基于数据驱动视图的强大功能。通过 class 绑定,可以动态更新元素的 class 属性,支持对象和数组语法,适用于普通元素和组件。style 绑定则允许以对象或数组形式动态设置内联样式,Vue 会根据数据变化自动更新 DOM。
Vue Router 简介
Vue Router 是 Vue.js 官方的路由管理库,用于构建单页面应用(SPA)。它将不同页面映射到对应组件,支持嵌套路由、路由参数和导航守卫等功能,简化复杂前端应用的开发。主要特性包括路由映射、嵌套路由、路由参数、导航守卫和路由懒加载,提升性能和开发效率。安装命令:`npm install vue-router`。

热门文章

最新文章

AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等