Vue中数组更新,达到更新数组的几种方法

本文详细介绍了在Vue.js中修改数组后确保页面重新渲染的四种有效方法,包括使用Vue.set、数组splice方法、$forceUpdate()以及ES6扩展运算符,帮助开发者解决数组更新后视图未同步的问题。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

最近面试问道和平时工作中用到:改变了数组内的值,但是页面没有重新渲染,今天记录下解决方法

直接修改不生效,代码如下

<template>
	<div>
		<h2>数组展示:{{testArr}}</h2>
		<button @click="changeArr">修改数组</button>
	</div>
</template>

<script>
	export default {
		name: "fun",
		data: function() {
			return {
				testArr:["a","b","c","d"]
			}
		},
		methods: {
			changeArr(){
			    // 这样直接修改数组是没用的,页面不会重新渲染
				this.testArr[1] = "w"
				console.log(this.testArr)
			}
		}
	}
</script>

在这里插入图片描述

第一种方法:Vue.set

changeArr(){
	// 这样直接修改数组是没用的,页面不会重新渲染
	this.testArr[1] = "w";

	//第一种方法: 用set来更新数据
	this.$set(this.testArr, 1, "Q")
	console.log(this.testArr)
}

在这里插入图片描述

该方法也能给对象新增属性,并更新试图:
给obj对象新增"newAttr"属性,并赋值为"hello world";
this.$set(this.obj, ‘newAttr’, ‘hello world’)

第二种方法:数组splice方法

changeArr(){
	// 第二种方法 splice
	this.testArr.splice(1, 1, "R")
	console.log(this.testArr)
}

在这里插入图片描述

第三种方法:this.$forceUpdate()强制刷新

changeArr(){
	// 第三种方法: this.$forceUpdate()强制刷新
	this.testArr[1] = "G"
	this.$forceUpdate();
	console.log(this.testArr)
}

在这里插入图片描述

第四种方法:es6 "…"扩展运算符

changeArr(){
	// 第四种方法: es6 "..."扩展运算符
	this.testArr[1] = "Y"
	this.testArr = [...this.testArr]
	console.log(this.testArr)
}

在这里插入图片描述

Vue.js 中,当你更改数组内容并希望视图自动更新时,通常情况下Vue并不会立即检测到这种变化并触发视图更新,因为Vue默认情况下只会监听数据属性的变化。对于数组,你需要手动触发一次组件内部的更新过程,也就是所谓的“强制更新”或“深度观察”。 以下是几种常见的强制更新数组方法: 1. **`this.$set(object, key, value)`**:Vue提供了专门用于设置新值并通知视图更新的 `$set` 方法。如果你直接赋值,Vue无法追踪到深层的变更。 ```javascript this.items = [...this.items.slice(0, i), newItem]; // 可能不行,试试 this.$set(this.items, i, newItem); ``` 2. **`Vue.nextTick()`**:在异步操作(如axios请求完成后)后调用,它会在DOM下次循环更新之前执行回调,此时可以对数据进行修改。 ```javascript axios.get('/data').then(response => { this.$nextTick(() => { this.array.push(response.data); }); }); ``` 3. **`$forceUpdate()`**:在组件实例上直接调用此方法,强制当前组件及其所有子组件重新渲染。 ```javascript this.$forceUpdate(); ``` 4. **`vm.$watch('array', callback, { deep: true })`**: 使用 `$watch` 监听数组的变化,并在发生变化时手动调用回调。 ```javascript this.$watch('array', () => { // 这里是你处理更新的代码 }, { deep: true }); ``` 记得,在大多数情况下,只要数据结构发生改变,Vue就应该能够检测到并更新视图,除非遇到了深层次的问题或者某些特殊场景。
评论 5
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值