首页
归档
笔记
树洞
搜索
友言

文章详情

Interesting People Record Interesting.

/ JavaScript / 文章详情

Vue2和Vue3的响应式原理

Sonder
2022-08-15
1577字
4分钟
浏览 (2k)

v3与v2的基本区别

  • 一、修改vue2和vue3双向数据绑定原理
  • 二、根节点的不同,template不再需要加一个元素包着内容了
  • 三、Composition API (组合api),像watch、compute需要引入才能调用
  • 四、生命周期的变化
  • 五、vue2和vue3的diff算法(更快,更小)
  • 六、v-if 和 v-for的优先级,v2中v-for高于v-if,v3中则相反,而且两者还能在同一标签中使用

Vue3

复制代码
// 1. Object.defineProperty => Proxy()
     // Vue2.x data中的属性做了遍历 + 递归, 给每一个属性设置getter, setter
     // data中预定义属性做出响应式

     // 2. Proxy()
     // 2.1 监听是针对一整个对象(完全代理所有属性)
     // 2.2 在目标对象之前假设一层拦截 => 外界访问该对象,必须通过这层拦截


     // 响应式重要特征 => 需要捕获到修改,做出对应的反应
     let obj = {
         name: '小明',
         age: 18
     }
     const p = new Proxy(obj, {
         // target => 源数据
         // 查
        get(target, propName){
            console.log(`读取了P的${propName}属性`)
            return target[propName]
            // return Reflect.get(target, propName)
        },
        // 改 + 增
        set(target, propName, value){
            console.log(`修改了P的${propName}属性,值为${value}`)
            target[propName] = value
        },
        // 删
        deleteProperty(target, propName){
            console.log(`删除了P的${propName}属性`)
            return delete target[propName] // 真,假
        }
     })

Vue2

复制代码
 let obj = {
                name: '小明'
            }
            let val = 20
            Object.defineProperty(obj, "age", {
                get() {
                    console.log(`age属性被读取${val}`)
                    return val;
                },
                set(newVal) {
                    console.log(`age属性被修改了,新值${newVal}`)
                    val = newVal
                }
            })
下一篇 / 手写一个Promise

🎯 相关文章

💡 推荐文章

🕵️‍♂️ 评论 (0)