【前端】vue数据监测原理

问题展示:

点击按钮之后,vue中的persons数据改变,但是页面显示的内容没变。(先点击按钮再打开vue的数据面板可以看见改变,先打开后点击数据面板也不能显示改变。)

此时的更新代码:

javascript 复制代码
methods:{
    updateMei:function(){
        this.persons[0] = {id:'001',name:'马老师',age:50,sex:'男'}
    }
}

没有问题的更新代码:

methods:{

//没问题的更新代码

updateMei:function(){

this.persons[0].name = "马保国" ;

this.persons[0].age = 50;

this.persons[0].sex = "男";

复制代码
}

}

有可能进行的是深度检测,在对象结构没发生变化的时候。

Vue数据监视原理

监视挂载步骤:

1.加工data:期望可以达到响应式数据更新的效果。---给对象的每个属性加get和set。

javascript 复制代码
//不行的版本
// Object.defineProperty(data,'name',{
//     get(){
//         return data.name;
//     },
//     set(val){
//         data.name = val;
//     }
// })

上述不可行的方案原因是因为data.name调用的也是get的方法,因此会一直递归。set中的data.name=val也是set的方法,也会一直递归。

javascript 复制代码
//创建一个监视的实例对象,用于监视data中的属性的变化
const obs = new Observer(data);

function Observer(obj){
    //汇总对象中的所有属性形成一个数组,获取所有的属性名
    const keys = Object.keys(obj);

    //遍历
    keys.forEach((k)=>{
        Object.defineProperty(this,k,{
            get(){
                return obj[k];
            },
            set(val){
                console.log(k+"改变了");
                obj[k] = val;
            }
        })
    })
}

上述可行是因为将get和set方法挂载在了obs对象上,只有调用obs.name去获取值以及设置值的时候才会使用get和set方法。如下图所示。

问题:为什么data改变的时候obs中的name也会变。

因为在obs对象中是引用了data的地址,并非自己创建了一个参数。跟c中一样。引用的是同一个对象。

2.vm._data = data = obs

Vue.set(target, key,val) / vm.$set(target, key,val)的使用

Api的作用:给vue对象data中的对象或者数组增加值。

javascript 复制代码
//给对象加
Vue.set(vm.student,'sex','男');

//给数组修改
Vue.set(vm.student.hobby,0,'打台球');

到这可以解释为什么直接修改数组中的值不奏效,因为数组没有给它设置get和set方法。

那数组怎么修改。vue只承认js数组方法中更改原数据的方法对数组进行修改。用他们更改可以奏效,vue对他们进行了重写、包装。

相关推荐
抹茶冰淇淋21 分钟前
降级系统后,2019年的Mac电脑重获新生
前端
雪碧聊技术1 小时前
前端VUE3项目部署到linux服务器(CentOS 7)
前端·linux部署vue3项目
汝生淮南吾在北4 小时前
SpringBoot+Vue饭店点餐管理系统
java·vue.js·spring boot·毕业设计·毕设
酒尘&7 小时前
JS数组不止Array!索引集合类全面解析
开发语言·前端·javascript·学习·js
学历真的很重要8 小时前
VsCode+Roo Code+Gemini 2.5 Pro+Gemini Balance AI辅助编程环境搭建(理论上通过多个Api Key负载均衡达到无限免费Gemini 2.5 Pro)
前端·人工智能·vscode·后端·语言模型·负载均衡·ai编程
用户47949283569159 小时前
"讲讲原型链" —— 面试官最爱问的 JavaScript 基础
前端·javascript·面试
用户47949283569159 小时前
2025 年 TC39 都在忙什么?Import Bytes、Iterator Chunking 来了
前端·javascript·面试
JIngJaneIL9 小时前
基于Java非遗传承文化管理系统(源码+数据库+文档)
java·开发语言·数据库·vue.js·spring boot
+VX:Fegn08959 小时前
计算机毕业设计|基于springboot + vue心理健康管理系统(源码+数据库+文档)
数据库·vue.js·spring boot·后端·课程设计
大怪v10 小时前
【Virtual World 04】我们的目标,无限宇宙!!
前端·javascript·代码规范