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

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

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

<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)
}

在这里插入图片描述

  • 14
    点赞
  • 31
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
Vue.js 提供了很多方便的指令来循环数组,以下是几种常见的方式: 1. 使用`v-for`指令 `v-for`指令是Vue.js最常用的指令之一,它可以用来循环数组、对象或数字。对于数组的循环,可以这样写: ``` <div v-for="(item, index) in items" :key="index">{{ item }}</div> ``` 其,`items`是要循环的数组,`item`是当前循环的元素,`index`是当前循环的索引。注意要为每个循环的元素设置一个唯一的`key`属性。 2. 使用`v-bind`指令 `v-bind`指令可以用来绑定DOM元素的属性,例如`class`、`style`等。对于数组的循环,可以这样写: ``` <div v-bind:class="{ active: item.isActive }" v-for="(item, index) in items" :key="index">{{ item }}</div> ``` 其,`item.isActive`是一个布尔值,如果为`true`,则给当前循环的元素添加一个`active`类。 3. 使用`v-model`指令 `v-model`指令可以用来实现双向数据绑定,对于数组的循环,可以这样写: ``` <div v-for="(item, index) in items" :key="index"> <input type="text" v-model="items[index]"> </div> ``` 其,`v-model`指令将输入框的值与数组对应索引的元素进行双向绑定。 4. 使用`computed`属性 如果需要对数组进行一些计算,例如过滤、排序等,可以使用`computed`属性来处理。例如: ``` computed: { filteredItems: function() { return this.items.filter(function(item) { return item.isActive; }); } } ``` 其,`filteredItems`是一个计算属性,它返回一个过滤后的数组。 以上是几种常见的循环数组的方式,根据不同的需求选择合适的方式可以使代码更加简洁、易读。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值