时间:2021-05-26
当vue的data里边声明或者已经赋值过的对象或者数组(数组里边的值是对象)时,向对象中添加新的属性,如果更新此属性的值,是不会更新视图的。
<template> <div id="app"> <p v-for="item in items" :key="item.id">{{item.message}}</p> <button class="btn" @click="handClick()">更改数据</button> </div></template><script>export default { name: 'App', data () { return { items: [ { message: "one", id: "1" }, { message: "two", id: "2" }, { message: "three", id: "3" } ] } }, mounted () { this.items[0] = { message:'first',id:'4'} //此时对象的值更改了,但是视图没有更新 // let art = {message:'first',id:"4"} // this.$set(this.items,0,art) //$set 可以触发更新视图 }, methods: { handClick(){ let change = this.items[0] change.message="shen" this.$set(this.items,0,change) } }}</script><style></style>调用方法: Vue.set( target , key , value)
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
如下所示:vm.items[indexOfItem]=newValuevue不能检测数组的变动想要实现可以使用vue的set方法this.$set(this.i
前言最近死磕了一段时间vue源码,想想觉得还是要输出点东西,我们先来从Vue提供的Vue.set()和this.$set()这两个api看看它内部是怎么实现的。
引文vue文档列表渲染中有条注意事项:这里提到的两种情况实际改变了数据但是没有触发视图更新。由此引出Vue.set(),先上文档API:this.$set()和
在vue中可以动态设置路由参数:1.使用this.$router.go(),与jshistroy.go()用法一直,前进1,后退-1,当前页面:0注意使用go时
1,文件内容----//为item添加不存在的属性,需要使用vue提供的Vue.set(object,key,value)方法。看详解:https://cn.v