深度理解vue 关于数组和对象的更新

在平常开发中,咱们用的最多的就是 绑定数据css

<div v-for="item in data" :key="item.id">
 <!-- 内容 -->
</div>
复制代码

若是你有ng的开发经验,假设 data 你要更新数据了html

this.data=res.data;vue

可是这在vue中 并不会起到做用,DOM并无触发变化。node

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

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

vue 关于数组和对象的更新

数组检测更细变异的方法面试

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

注意事项数组

因为 JavaScript 的限制,Vue 不能检测如下变更的数组:bash

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()
//
介绍一个全栈开发交流学习圈,欢迎加入Q群:864305860
复制代码

了解更多 本次给你们推荐一个免费的学习群,里面归纳移动应用网站开发,css,html,webpack,vue node angular以及面试资源等。 对web开发技术感兴趣的同窗,欢迎加入Q群:864305860,无论你是小白仍是大牛我都欢迎,还有大牛整理的一套高效率学习路线和教程与您免费分享,同时天天更新视频资料。 最后,祝你们早日学有所成,拿到满意offer,快速升职加薪,走上人生巅峰。

相关文章
相关标签/搜索