北京乐逍遥网站设计有限公司|乐逍遥网站设计|乐逍遥网站建设|乐逍遥建站|php知识|前端技术|后端技术|网站源码|移动开发|网站运营|UI设计|数据库|网站设计|网站开发|小程序|乐逍遥每日一句|乐逍遥福利图片
主页 > 前端开发 > Vue.js >

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

时间:2020-03-19  编辑:

前言

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

双向数据绑定

Vue2是如何做到数据绑定的

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

关于数组与基本数据类型的奇葩现象

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

 let vm = new Vue({
        el:'#app',
        template:`
        <div>
          <p v-for="n in arr" >
            {{n}}
          </p>
        </div>`,
        data(){
          return {
            arr:[1,2,3]
          }
        }
    });

现在我们改变其中的元素值

file

解答疑问

想办法解决

听说有个函数可以让Vue知道你在添加属性,并完成响应式。Vue.set(obj.key.value);

哇,有效果!!

我们再来改变他看看是否能双向数据绑定

file

哦! No!看看源码

file
看到了吗? 基本(原始)数据类型还给个警告!!

file
往下执行,如果是数组直接结束了,并不做reactive操作哦

总结

之前讲解了Vue做数据劫持是基于Object.defineProperty的,但是他只能做set和get,而无法监视到属性的增加或者减少,这点倒是可以用Vue.set(obj.key.value)解决!而数组+基本数据类型不行! 当然话说回来,真实业务中,直接用数组操作基本数据类型的场景还真不多!关于如何解决这一系列问题,请持续关注我

返回
顶部