vue 数组和对象不能直接赋值情况和解决方法(推荐)


Posted in Javascript onOctober 25, 2017

Vue 不能检测以下变动的数组:

当你利用索引直接设置一个项时,例如:vm.items[indexOfItem] = newValue

当你修改数组的长度时,例如:vm.items.length = newLength

当第一种情况需求时,可以使用this.$set(this.arr,index,newVal)

Vue 不能检测对象属性的添加或删除:

可以使用this.$set(this.person,'age',12)

     当需要添加多个对象时,Object.assign({},this.person,{age:12,name:'wee'})

PS:Vue实现对数组、对象的深拷贝、复制

当组件间传递对象时,由于此对象的引用类型指向的都是一个地址(除了基本类型跟null,对象之间的赋值,只是将地址指向同一个,而不是真正意义上的拷贝),如下

数组:

var a = [1,2,3];
var b = a;
b.push(4); // b中添加了一个4
alert(a); // a变成了[1,2,3,4]

对象:

var obj = {a:10};
var obj2 = obj;
obj2.a = 20; // obj2.a改变了,
alert(obj.a); // 20,obj的a跟着改变

这就是由于对象类型直接赋值,只是将引用指向同一个地址,导致修改了obj会导致obj2也被修改

所以在vue中,如果多个组件引用了同一个对象作为数据,那么当其中一个组件改动对象数据时,其他对象的数据也会同步改动。有这种双向绑定的需要的话,那么自然是最好的,但如果不需要这种绑定而希望各组件的对象数据之间相互独立,即是互不关联的对象副本的话,可以用下面的方法解决

computed: { 
   data: function () { 
     var obj={}; 
     obj=JSON.parse(JSON.stringify(this.templateData)); //this.templateData是父组件传递的对象 
     return obj 
  } 
 }

总结

以上所述是小编给大家介绍的vue 数组和对象不能直接赋值情况和解决方法,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
js 获取(接收)地址栏参数值的方法
Apr 01 Javascript
jQuery操作表单常用控件方法小结
Mar 23 Javascript
JavaScript中setTimeout和setInterval函数的传参及调用
Mar 11 Javascript
在IE8上JS实现combobox支持拼音检索功能
May 23 Javascript
学习Bootstrap滚动监听 附调用方法
Jul 02 Javascript
ajax图片上传,图片异步上传,更新实例
Dec 30 Javascript
基于HTML5+JS实现本地图片裁剪并上传功能
Mar 24 Javascript
axios向后台传递数组作为参数的方法
Aug 11 Javascript
Vue项目打包部署到iis服务器的配置方法
Oct 14 Javascript
mpvue实现左侧导航与右侧内容的联动
Oct 21 Javascript
浅谈Vue 自动化部署打包上线
Jun 14 Javascript
js实现上传图片到服务器
Apr 11 Javascript
JS使用tofixed与round处理数据四舍五入的区别
Oct 25 #Javascript
javascript计算对象长度的方法
Oct 25 #Javascript
AngularJS实现的select二级联动下拉菜单功能示例
Oct 25 #Javascript
Angular4实现鼠标悬停3d倾斜效果
Oct 25 #Javascript
详解vue 组件之间使用eventbus传值
Oct 25 #Javascript
bootstrap时间控件daterangepicker使用方法及各种小bug修复
Oct 25 #Javascript
Windows安装Node.js报错:2503、2502的解决方法
Oct 25 #Javascript
You might like
【COS正片】蕾姆睡衣cos,纯洁可爱被治愈了 cn名濑弥七
2020/03/02 日漫
Php部分常见问题总结
2006/10/09 PHP
php print EOF实现方法
2009/05/21 PHP
PHP 实现代码复用的一个方法 traits新特性
2015/02/22 PHP
Yii2中多表关联查询hasOne hasMany的方法
2017/02/15 PHP
php常用字符串查找函数strstr()与strpos()实例分析
2019/06/21 PHP
jQuery侧边栏随窗口滚动实现方法
2013/03/04 Javascript
javascript中怎么做对象的类型判断
2013/11/11 Javascript
JS简单实现元素复制示例附图
2013/11/19 Javascript
javascript实现滑动解锁功能
2014/12/31 Javascript
jQuery无刷新切换主题皮肤实例讲解
2015/10/21 Javascript
使用javaScript动态加载Js文件和Css文件
2015/10/24 Javascript
js中substr,substring,indexOf,lastIndexOf,split,replace的用法详解
2015/11/09 Javascript
JS清除文本框内容离开在恢复及鼠标离开文本框时触发js的方法
2016/01/12 Javascript
jQuery中Ajax全局事件引用方式及各个事件(全局/局部)执行顺序
2016/06/02 Javascript
Bootstrap基本插件学习笔记之轮播幻灯片(23)
2016/12/08 Javascript
微信小程序 天气预报开发实例代码源码
2017/01/20 Javascript
React进阶学习之组件的解耦之道
2017/08/07 Javascript
vue 过滤器filter实例详解
2018/03/14 Javascript
原生实现一个react-redux的代码示例
2018/06/08 Javascript
微信小程序实现的日期午别医生排班表功能示例
2019/01/09 Javascript
Node.js+Express+Mysql 实现增删改查
2019/04/03 Javascript
vue-cli4项目开启eslint保存时自动格式问题
2020/07/13 Javascript
Vue使用Proxy代理后仍无法生效的解决
2020/11/13 Javascript
Python打印斐波拉契数列实例
2015/07/07 Python
Python 爬虫多线程详解及实例代码
2016/10/08 Python
详解Python给照片换底色(蓝底换红底)
2019/03/22 Python
python基于pdfminer库提取pdf文字代码实例
2019/08/15 Python
python实现串口通信的示例代码
2020/02/10 Python
Python生成器常见问题及解决方案
2020/03/21 Python
Python如何在循环内使用list.remove()
2020/06/01 Python
推荐WEB开发者最佳HTML5和CSS3代码生成器
2015/11/24 HTML / CSS
.NET面试问题集
2015/12/08 面试题
本科生就业推荐信
2014/05/19 职场文书
纺织工程专业推荐信
2014/09/08 职场文书
详解运行Python的神器Jupyter Notebook
2021/06/03 Python