mpvue踩坑之setter触发相关&Vue中数组和对象更改后视图不刷新的问题

本文介绍了在mpvue和Vue中遇到的数组和对象更改后视图无法刷新的问题,分析了原因并提出了解决方案,包括使用`Vue.set`或直接赋值触发setter来更新视图。同时,指出mpvue可能存在一些未解决的坑,如`push()`和`splice()`不触发setter。
摘要由CSDN通过智能技术生成

vue以及mpvue中数组或对象中的数据发生改变后视图层没刷新的问题

发现这个问题是因为自己在写学委小程序/高校班级助手的时候,使用的是mpvue框架,使用vue的语法来写小程序的,当遇到了上传图片或者上传文件的时候,由于$data中的数据结构形式使用的跟以往的不太一样,代码片段如下:

data() {
	return {
		bgIsTransparent: false,
		dateTimeArray: [],
		dateTime: [],
		showCalendar: false,
		value: [],
		// homeworkPhoto: [], // 图片上传 ps:以前的写法
		store: {
			course: '',
			title: '',
			content: '',
			deadline: '',
			homeworkPhoto: [], // 图片上传 ps:现在的写法
			files: [] // 文件上传
		}
	};
},

正如以上的代码所示,按照以前的写法,我基本上都是将要使用到的数据字段直接放在 $data下面,很少像现在这样子放在 $data中的一个字段来进行统一维护的。因此改成现在这样子的写法之后,虽然在管理数据的时候似乎是方便了很多,但是由于vue特别是mpvue对数据响应式的处理似乎有点问题,mpvue框架本身bug的问题吧应该是,就会造成如标题所描述的问题,就是数组和对象更改后视图不刷新的问题。

一般来说,按照vue官方文档所说,如果想要动态的给一个对象添加一个属性,需要使用vue.set或者vm. $set来添加响应式的属性,只有这样子写才会给属性添加上getter和setter,这样子才能做到在响应式系统内触发状态更新。但是呢这次的情况跟以往的不一样,以往的是给对象动态添加属性,但是这次的是给对象中的属性(这里是一个数组)动态的添加元素,我尝试过使用vue.set或者vm. $set来解决问题,会这样想是因为数组本质上其实也是一个对象,数组的下标也就是index索引其实也就是对象的键值对中的键,这样子理解的话就会理所当然地想到了使用vue.set或者vm. $set,然而并不起作用。

查看了vue官方文档以及参考了他人的博文,似乎找到了解决办法。
在这里插入图片描述
在这里插入图片描述
按照官方的说法,通过赋值改变改变整个属性,就可以触发setter

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 当我们直接对Vue数组进行赋值操作时,页面并不会重新渲染,这是Vue的响应式机制导致的。在Vue,对于数组的变异操作(比如push、pop、shift、unshift、splice、sort和reverse等)会被Vue捕获到,并对视图进行更新。这是因为Vue重写了数组的一些方法,使其具有监听变化的能力。 然而,直接对数组进行赋值的操作无法被Vue捕获到,因此不会触发视图的更新。这是因为Vue并没有重写数组的赋值操作符。 为了解决这个问题,我们可以使用Vue提供的set方法或者使用Vue的特殊方法$set来实现。$set方法的语法为Vue.set(target, propertyName/index, value),可以通过target对象的属性名或者索引来设置新的值。 还有一种解决方法是使用深拷贝来实现页面的重新渲染。我们可以使用Vue提供的工具函数Vue.set或者通过JSON.stringify和JSON.parse来实现深拷贝。具体操作可以参考Vue的官方文档。这样做的目的是使得Vue能够监听到数组的变化,从而触发视图的更新。 总之,直接对Vue数组进行赋值是无法触发视图的更新的。我们需要使用Vue提供的特殊方法来实现数组的修改和页面的重新渲染。 ### 回答2: 当我们直接对Vue数组进行赋值操作时,页面不会自动渲染是因为Vue的响应式系统没有检测到对数组的变化。 在Vue,其响应式系统是利用Object.defineProperty()方法来劫持对象的属性,并通过监听属性的getter和setter方法来实现数据的响应式更新。但是对于数组来说,由于JavaScript的限制,Vue无法通过Array的原型方法来劫持数组的变化。 在这种情况下,Vue提供了一些特殊的方法来对数组进行操作,例如push()、pop()、shift()、unshift()等。这些方法会在数组发生变化时触发Vue的响应式系统,从而更新页面。 而当我们直接对数组进行赋值操作时,Vue的响应式系统无法捕获到这种变化,因此页面不会自动重新渲染。如果我们需要对数组进行重新赋值操作,可以使用Vue提供的$set()方法,它能够将新的数组设置为响应式的,并触发页面的重新渲染。 例如: ```javascript this.array = []; // 直接赋值,页面不会渲染 this.array = this.$set(this.array, newArray); // 使用$set()方法重新赋值,页面会重新渲染 ``` 总结来说,直接对Vue数组进行赋值操作时,需要使用Vue提供的特殊方法来更新数组,否则页面不会重新渲染。 ### 回答3: 在Vue数组直接赋值会导致页面不渲染的原因是因为Vue对数据的变化具有响应式的机制。当我们直接给数组赋值时,Vue无法检测到这种变化,并且不会更新页面。 在Vue,如果我们想要让页面渲染数组的变化,我们需要使用Vue提供的特殊方法来更新数组,例如使用`push`方法向数组末尾添加元素或使用`splice`方法删除数组的元素。这样,Vue会感知到数组的变化并重新渲染页面。 以下是一个示例,展示了如何在Vue正确更新数组实现页面渲染: ```html <template> <div> <ul> <li v-for="item in items" :key="item">{{ item }}</li> </ul> <button @click="addItem">添加元素</button> </div> </template> <script> export default { data() { return { items: ['元素1', '元素2', '元素3'] }; }, methods: { addItem() { this.items.push('新元素'); } } }; </script> ``` 在上述示例,我们通过`v-for`指令将数组的每个元素渲染为一个`li`元素。当点击按钮时,`addItem`方法会通过`push`将一个新元素添加数组。由于使用了正确的更新数据方法,Vue能够检测到数组的变化并重新渲染新的元素。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值