Vue中你可能认为是bug的情况原来是这样的

本文探讨Vue框架的双向数据绑定原理,解释为何改变数组中基本数据类型元素不会更新视图,并提出解决方案——使用Vue.set()。通过实例展示了在尝试直接修改数组元素时,Vue不会进行响应式更新,同时提醒开发者注意基本数据类型在数组中的特殊性。
摘要由CSDN通过智能技术生成
前言

我们知道Vue框架剧本双向数据绑定功能,在我们使用方便的同时,还有一些细节问题我们并不知道,接下来一起探讨一些吧

双向数据绑定

  • js变量改变影响页面
  • 页面改变影响js变量
Vue2是如何做到数据绑定的

Object.defineProperty(obj,key,{
                set:function (newV) {
                    val = newV;
                     // 通知所有用到这个属性的DOM更新
                    dep.notifyAll();
                },
                get:function () {
                    if (Dep.currentSub) {
                         // 对这个属性,新订阅一个元素
                        dep.subscribe(); 
                    }
                    return val;
                }
            });

  • 以上需要说的就是: Vue中data函数返回的对象,会经过层层遍历,最后将所有的对象通过以上方法,把其属性进行监视。
    • 通过xxx.xxx = 'xxx' 就会触发set函数
    • 通过xxx.xxx 就会触发get函数
关于数组与基本数据类型的奇葩现象

我们声明好数组,其中放置基本数据类型

 let vm = new Vue({
        el:'#a
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值