在日常开发中, 我们用的最多的就是 绑定数据
- <div v-for="item in data" :key="item.id">
- <!-- 内容 -->
- </div>
如果你有 ng 的开发经验, 假设 data 你要更新数据了
this.data=res.data;
但是这在 vue 中 并不会起到作用, DOM 并没有触发变化.
vue 不是已经实现的实时数据双向绑定, 那么 model 层发生了变化之后, 为什么 view 层没有更新呢???
看官网 这里才发现 深入响应式原理 列表渲染
数组检测更细变异的方法
- push()
- pop()
- shift()
- unshift()
- splice()
- sort()
- reverse()
注意事项
由于 JavaScript 的限制, Vue 不能检测以下变动的数组:
- this.data[index] = res.data;
- this.data.length = 0;
正确的操作方式
- Vue.$set(this.data, 1, {name:"huangenai",age:"22"})
- 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()
- //
来源: http://www.qdfuns.com/article/51117/6b293a0d5297ce5b3abd252216bf4326.html