最新文章专题视频专题问答1问答10问答100问答1000问答2000关键字专题1关键字专题50关键字专题500关键字专题1500TAG最新视频文章推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37视频文章20视频文章30视频文章40视频文章50视频文章60 视频文章70视频文章80视频文章90视频文章100视频文章120视频文章140 视频2关键字专题关键字专题tag2tag3文章专题文章专题2文章索引1文章索引2文章索引3文章索引4文章索引5123456789101112131415文章专题3
当前位置: 首页 - 科技 - 知识百科 - 正文

vue 对象添加或删除成员时无法实时更新的解决方法

来源:动视网 责编:小采 时间:2020-11-27 21:57:45
文档

vue 对象添加或删除成员时无法实时更新的解决方法

vue 对象添加或删除成员时无法实时更新的解决方法:前阵子将项目搬上Vue的时候偶遇一个突发问题 当对象添加或删除成员时页面无法实时更新渲染,但是数组是正常的 目测是ob没有监听到对象的成员有变化 查看一些大家的求助回答是说ob监听的是数组length的变动 对象默认没有length 新增成员时不会自增length
推荐度:
导读vue 对象添加或删除成员时无法实时更新的解决方法:前阵子将项目搬上Vue的时候偶遇一个突发问题 当对象添加或删除成员时页面无法实时更新渲染,但是数组是正常的 目测是ob没有监听到对象的成员有变化 查看一些大家的求助回答是说ob监听的是数组length的变动 对象默认没有length 新增成员时不会自增length


前阵子将项目搬上Vue的时候偶遇一个突发问题

当对象添加或删除成员时页面无法实时更新渲染,但是数组是正常的

目测是ob没有监听到对象的成员有变化

查看一些大家的求助回答是说ob监听的是数组length的变动 对象默认没有length 新增成员时不会自增length

所以监听不到对象的变化 最近大脑过于疲惫 懒得看文档了。。

不多废话 解决方式直接上代码

在实例内部可以用$set和$delete

this.$set(this.age,'age',18);
this.$delete(this.age,'age');

也可以直接调用Vue的set和delete

let vm = new Vue({
 el : '#app',
 data : {
 age:{}
 }
});
Vue.set(vm.age,'age',18);
Vue.delete(vm.age,'age');

PS:vue给数组和对象进行增加删除字段不更新数据的解决方法 — Vue.set(object, key, value)

组件基本代码:

<style lang="sass">

</style>
<template>
<div>
 <div>
 <div>

 </div>
 </div>
</div>
</template>
<script>
 export default {
 data(){
 return {

 }
 },
 methods: {
 ceshi(){

 }
 }
 }
</script>

1.数组的增加,删除(数组的push等方法排除)

</style>
<template>
<div>
 <div>
 <div>
 <div v-for="item in items">
 <span>{{ item }}</span>
 </div>
 <button @click="ceshi">anniu</button>
 </div>
 </div>
</div>
</template>

<script>
 export default {
 data(){
 return {
 items: [11,22],
 obj: { a: 'aa', b: 'bb' }
 }
 },
 methods: {
 ceshi(){
 this.items[2] = 33; // 这样的写法数据是无法重新渲染的
 }
 }
 }
</script>

点击按钮操作ceshi事件前后,没发生变化

解决方法:

就是利用数据的push方法是可以实现的

利用Vue.set方法

具体实现如下:

methods: {
 ceshi(){
 this.$set(this.items, 2, 33)
 }
},

同理,如果items: [{a: ‘11'}] –> items: [{a: ‘11', b: ‘22'}]

<div v-for="item in items">
 <span v-for="(i, j) in item">{{ i }}--{{ j }}</span>
</div>

this.items[0] = Object.assign({}, this.items[0], { b: '22' });
this.$set(this.items, 0, this.items[0]);

2.给对象增加新属性(同理)

<template>
 <div>
 <div v-for="item in obj">
 <span>{{ item }}</span>
 </div>
 </div>
</template>

data(){
 return {
 obj: { a: 'aa', b: 'bb' }
 }
}

methods: {
 ceshi(){
 this.obj['c'] = '000'; // 不起作用
 this.$set(this.obj, 'c', '000'); //起作用 
 }
},

文档

vue 对象添加或删除成员时无法实时更新的解决方法

vue 对象添加或删除成员时无法实时更新的解决方法:前阵子将项目搬上Vue的时候偶遇一个突发问题 当对象添加或删除成员时页面无法实时更新渲染,但是数组是正常的 目测是ob没有监听到对象的成员有变化 查看一些大家的求助回答是说ob监听的是数组length的变动 对象默认没有length 新增成员时不会自增length
推荐度:
  • 热门焦点

最新推荐

猜你喜欢

热门推荐

专题
Top