博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
vue 关于数组和对象的更新
阅读量:4627 次
发布时间:2019-06-09

本文共 914 字,大约阅读时间需要 3 分钟。

在日常开发中,我们用的最多的就是 绑定数据
<div v-for="item in data" :key="item.id"> <!-- 内容 --></div>

如果你有ng的开发经验,假设 data 你要更新数据了

this.data=res.data;

但是这在vue中 并不会起到作用,DOM并没有触发变化。

vue不是已经实现的实时数据双向绑定,那么model层发生了变化之后,为什么view层没有更新呢???

看官网 这里才发现 深入响应式原理 列表渲染

vue 关于数组和对象的更新

数组检测更细变异的方法

push()pop()shift()unshift()splice()sort()reverse()

注意事项

由于 JavaScript 的限制,Vue 不能检测以下变动的数组:

  1. this.data[index] = res.data;
  2. this.data.length = 0;

正确的操作方式

  1. Vue.$set(this.data, 1, {name:"huangenai",age:"22"})
  2. vm.items.splice(0)

对象

还是由于 JavaScript 的限制,Vue 不能检测对象属性的添加或删除:

<script> export default { data(){ return { userProfile: { name: 'Anika' } user: { name: "huangenai", age: 12 } } }, mounted() { this.$set(this.userProfile, 'age', 27) this.user = Object.assign({}, this.user, { age: 22, name: "huangenai" }); } }</script>

Vue提供了如下的数组的变异方法,可以触发视图更新

push()pop()shift()unshift()splice() sort()reverse()

原文地址:

转载于:https://www.cnblogs.com/lalalagq/p/9901006.html

你可能感兴趣的文章
Centos 下 Jenkins2.6 + Git + Maven Shell一件部署与备份
查看>>
MVC原理
查看>>
Java中堆内存和栈内存详解
查看>>
网络编程
查看>>
C# 访问USB(HID)设备方法 (转)
查看>>
linux 配置svn服务器+使用+注意事项
查看>>
关于JAVA并发编程你需要知道的——语言篇
查看>>
Spring MVC 中 HandlerInterceptorAdapter的使用
查看>>
druid 数据源 使用属性文件的一个坑
查看>>
[na]数据包由于isp不稳定丢包-seq&ack
查看>>
浅谈Web前端浏览器兼容问题
查看>>
用命令行在github新建一个项目
查看>>
测一下我心中想的事
查看>>
java中getName()、getCanonicalName()、getSimpleName()用法比较
查看>>
React Native pod install报错 `Yoga (= 0.44.3.React)` required by `React/Core (0.44.3)`
查看>>
C#中 删除掉字符串数组中的空字符串
查看>>
Win10 驱动装不上,提示:Windows 无法验证此设备所需的驱动程序的数字签名。该值受安全引导策略保护,无法进行修改或删除。...
查看>>
数值计算小问题
查看>>
A股行情记录
查看>>
集合(下)
查看>>