开发者社区> 问答> 正文

Vue不能检测到Object/Array更新的情况的解决

Vue不能检测到Object/Array更新的情况的解决

展开
收起
社区秘书 2019-12-16 14:48:00 994 0
1 条回答
写回答
取消 提交回答
  • 
    数组
    
    索引
    
    使用下标更新数组元素;
    使用赋值方式改变数组长度;
    使用下标增删数组元素;
    正文
    
    使用下标更新数组元素
    
    data: {
      arrs: [0, 1, 2, 3]
    }
    直接使用this.arrs[0] = 'zero';虽然数组确实是被更新了,但是更新不会被渲染到视图(html页面)上。因为Vue没有检测到数组的更新。
    
    由于 JavaScript 的限制,Vue 不能检测以下变动的数组:
    
    当你利用索引直接设置一个项时,例如:vm.items[indexOfItem] = newValue 当你修改数组的长度时,例如:vm.items.length = newLength
    
    官方应对方法:
    
    1、Vue.set( target, key, value )
    
    Vue.set(this.arrs, 0, 'zero');
    2.vm.items.splice(indexOfItem, 1, newValue)
    
    this.arrs.splice(0, 1, 'zero');
    前端全栈学习交流圈:866109386,面向1-3经验年前端开发人员,帮助突破技术瓶颈,提升思维能力,群内有大量PDF可供自取,更有干货实战项目视频进群免费领取。
    
    使用赋值方式改变数组长度 即this.arrs.length = 100;无效! 官方应对方法: 1、vm.items.splice(newLength)
    
    this.arrs.splice(100);
    使用下标增删数组元素 即一下操作无效:
    
    this.arrs[this.arrs.length] = this.arrs.length;
    官方应对方法:变异方法。
    
    push()
    pop()
    shift()
    unshift()
    splice()
    sort()
    reverse()
    this.arrs.push(this.arrs.length);
    8、替换数组(改变引用) 如官方所言:filter(), concat() 和 slice()都是会返回一个新数组
    
    this.arrs = this.arrs.contact(this.arrs.length);
    // or
    // this.arrs = this.arrs.contact([this.arrs.length]);
    官方对性能问题的回应:
    
    你可能认为这将导致 Vue 丢弃现有 DOM 并重新渲染整个列表。幸运的是,事实并非如此。Vue 为了使得 DOM 元素得到最大范围的重用而实现了一些智能的、启发式的方法,所以用一个含有相同元素的数组去替换原来的数组是非常高效的操作。
    
    前端全栈学习交流圈:866109386,面向1-3经验年前端开发人员,帮助突破技术瓶颈,提升思维能力,群内有大量PDF可供自取,更有干货实战项目视频进群免费领取。
    
    对象
    
    索引
    
    增删元素;
    
    正文
    
    data: {
     foo: { name: 'isaac' }
    }
    增删元素
    
    this.foo.job = 'coder';
    delete this.foo.name;
    如上增删元素是无效的。
    
    官方的解决方法:
    
    // 新增
    Vue.set(this.foo, 'job', 'coder');
    
    // 删除
    Vue.delete(this.foo, 'name');
    Vue.delete对数组也是有效传送门
    
    2019-12-16 14:48:13
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
Vue.js 在前端服务化上的探索与实践 立即下载
Vue.js在前端服务化上的实践与探索 立即下载
利用编译将 Vue 组件转成 React 组件 立即下载