温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

Vue对象和数据怎么强制更新

发布时间:2022-04-02 15:43:17 来源:亿速云 阅读:418 作者:iii 栏目:开发技术

本文小编为大家详细介绍“Vue对象和数据怎么强制更新”,内容详细,步骤清晰,细节处理妥当,希望这篇“Vue对象和数据怎么强制更新”文章能帮助大家解决疑惑,下面跟着小编的思路慢慢深入,一起来学习新知识吧。

对象和数据的强制更新

数组更新

以下支持自动更新

  • push() //向后添加

  • pop() //删除最后一个

  • shift() //删除第一个

  • unshift() //向第一个添加元素

  • splice() //向指定位置添加/删除元素

  • sort() //用原地算法对数组的元素进行排序

  • reverse() //将数组中元素的位置颠倒

注意,这种形式修改数据 this.arr[1] = ‘x’ // 不是响应性的,这种情况,可以采用splice方法修改数据即可实现更新

强制更新

this.$set(数组,下标,修改后的值)

eg:this.$set(this.dataArr,1,{})

对象更新

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

强制更新

this.$set(this.obj, ‘age', 27)

参考链接 

更新数据并强制更新视图

在开发过程中,有时发现当数据变动后,视图并未更新。那么下面是一些常见示例的和解决办法

对象类型

当对象为引用类型,vue不一定能监控到 所以当我们新建一个对象并赋值给oldObj字段的话,直接改变了它的指向地址=====》对象和数组都能用的方法:

this.$set(this,'oldArray',newArray);
this.$set(this,'oldObj',newObj);
this.$set(this.some.name,‘b',2)

数组类型

这些不会改变原始数组,但总是返回一个新数组。当使用非变异方法时,可以用新数组替换旧数组。

push(),pop(),shift(),unshift(),splice(),sort(),reverse()可被vue检测到 ,filter(), concat(), slice() 。

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

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

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

异步类型

可在数据变化之后立即使用 

Vue.nextTick(callback)

这样回调函数在 DOM 更新完成后就会调用。

强制更新

this.$forceUpdate(),强制视图更新 

vue多层循环,动态改变数据后渲染的很慢或者不渲染。

比如v-for里面数据层次太多, 修改过数据变了,页面没有重新渲染,需手动强制刷新。

读到这里,这篇“Vue对象和数据怎么强制更新”文章已经介绍完毕,想要掌握这篇文章的知识点还需要大家自己动手实践使用过才能领会,如果想了解更多相关内容的文章,欢迎关注亿速云行业资讯频道。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

vue
AI