vue替换数组对象的某个属性值

通过$set给某个属性从新赋值,具体参照官网https://cn.vuejs.org/v2/api/#vm-set
data:[
	{name: 'xxx', status: 0},
	{name: 'xxx', status: 1},
	{name: 'xxx', status: 0},
	{name: 'xxx', status: 1},
]


data.forEach(item => {
	if (item.status === 0) {
		// 'status'为属性名,'非活动'为修改后的内容 
		this.$set(item, 'status', '非活动')
	} else if (item.status === 1) {
		this.$set(item, 'status', '活动')
	}
})
注意$set只在vue的js中生效,当提取为公共方法写在js中时,this.$set会报错undefined,在js中写法为
data:[
	{name: 'xxx', status: 0},
	{name: 'xxx', status: 1},
	{name: 'xxx', status: 0},
	{name: 'xxx', status: 1},
]


data.forEach(item => {
	if (item.status === 0) {
		// 'status'为属性名,'非活动'为修改后的内容 
		item.status = '非活动'
	} else if (item.status === 1) {
		item.status = '活动'
	}
})
  • 5
    点赞
  • 25
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Vue中,我们可以使用 `Vue.set()` 或 `Object.assign()` 方法将一个数组对象赋值给另一个数组对象。 下面是两种实现方式的示例代码: 1. 使用 `Vue.set()` ```javascript // 定义两个数组对象 let array1 = [{ id: 1, name: 'Tom' }, { id: 2, name: 'Jerry' }]; let array2 = [{ id: 3, name: 'Alice' }, { id: 4, name: 'Bob' }]; // 将 array2 的赋值给 array1 array1.forEach((item, index) => { Vue.set(item, 'name', array2[index].name); }); console.log(array1); // 输出结果为 [{ id: 1, name: 'Alice' }, { id: 2, name: 'Bob' }] ``` 在上面的代码中,我们使用 `forEach()` 方法循环遍历 `array1` 数组,使用 `Vue.set()` 方法将 `array2` 数组中的 `name` 属性赋值给 `array1` 数组中的同一属性。最终,`array1` 数组中的 `name` 属性就被替换成了 `array2` 数组中的。 2. 使用 `Object.assign()` ```javascript // 定义两个数组对象 let array1 = [{ id: 1, name: 'Tom' }, { id: 2, name: 'Jerry' }]; let array2 = [{ id: 3, name: 'Alice' }, { id: 4, name: 'Bob' }]; // 将 array2 的赋值给 array1 array1 = array1.map((item, index) => Object.assign({}, item, { name: array2[index].name })); console.log(array1); // 输出结果为 [{ id: 1, name: 'Alice' }, { id: 2, name: 'Bob' }] ``` 在上面的代码中,我们使用 `map()` 方法循环遍历 `array1` 数组,使用 `Object.assign()` 方法将 `array2` 数组中的 `name` 属性赋值给 `array1` 数组中的同一属性,并返回一个新的数组对象。最终,`array1` 数组就被替换成了新的数组对象,其中 `name` 属性替换成了 `array2` 数组中的

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值