vue 对象、数组增删改,对比vue2和vue3 —— 最新总结2025

一、对象操作对比

1. Vue 2 的对象操作

  • 新增属性 :无法直接通过 obj.newKey = 'value' 添加响应式属性,需使用 Vue.setthis.$set
javascript 复制代码
this.$set(this.obj, 'newKey', 'value'); // 触发响应式更新
  • 删除属性 :无法直接通过 delete obj.key 删除响应式属性,需使用 Vue.deletethis.$delete
javascript 复制代码
this.$delete(this.obj, 'key'); // 触发响应式更新
  • 修改属性:直接修改属性值可触发响应式更新。
javascript 复制代码
this.obj.key = 'newValue'; // 触发响应式更新

2. Vue 3 的对象操作

新增属性 :直接通过 obj.newKey = 'value' 添加属性即可触发响应式更新,无需手动调用 $set
javascript 复制代码
const obj = reactive({ key: 'value' });
obj.newKey = 'newValue'; // 自动触发响应式更新
  • 删除属性 :直接通过 delete obj.key 删除属性即可触发响应式更新,无需手动调用 $delete
javascript 复制代码
delete obj.key; // 自动触发响应式更新
  • 修改属性:直接修改属性值可触发响应式更新。
javascript 复制代码
obj.key = 'newValue'; // 自动触发响应式更新

二、数组操作对比

1. Vue 2 的数组操作

新增元素 :需使用数组变异方法(如 pushunshiftsplice)或通过 $set 修改索引。

javascript 复制代码
this.items.push(newItem); // 触发响应式更新
this.$set(this.items, this.items.length, newItem); // 触发响应式更新


一、对象(Object)操作

1. 添加/修改属性

javascript 复制代码
// ❌ 错误 - 不会触发响应式更新
this.obj.newKey = 'value'

// ✅ 正确 - Vue 2
this.$set(this.obj, 'newKey', 'value')

// ✅ 正确 - Vue 3
import { reactive } from 'vue'
const obj = reactive({})
obj.newKey = 'value'  // Vue 3 中可以直接添加

// ✅ 正确 - 重新赋值(两种版本都适用)
this.obj = {
  ...this.obj,
  newKey: 'value'
}

2. 删除属性

javascript 复制代码
// ❌ 错误
delete this.obj.property

// ✅ 正确 - Vue 2
this.$delete(this.obj, 'property')

// ✅ 正确 - Vue 3
delete this.obj.property  // Vue 3 中可以直接删除

// ✅ 正确 - 重新赋值
const { property, ...rest } = this.obj
this.obj = rest

3. 嵌套对象操作

javascript 复制代码
// ✅ 正确 - 深度修改
this.$set(this.user, 'profile', { name: 'John' })

// ✅ 嵌套属性修改
this.$set(this.user.profile, 'age', 25)

// ✅ 使用 Vue 3 Composition API
import { reactive } from 'vue'
const state = reactive({
  user: {
    profile: {}
  }
})
state.user.profile.name = 'John'  // 自动响应

二、数组(Array)操作

1. 变异方法(可触发响应式更新)

javascript 复制代码
// ✅ push - 末尾添加
this.items.push(newItem)
this.items.push(item1, item2, item3)  // 添加多个

// ✅ pop - 末尾删除
this.items.pop()

// ✅ shift - 开头删除
this.items.shift()

// ✅ unshift - 开头添加
this.items.unshift(newItem)

// ✅ splice - 增删改
// 删除:从索引2开始删除1个元素
this.items.splice(2, 1)

// 替换:从索引2开始删除1个元素,添加新元素
this.items.splice(2, 1, newItem)

// 添加:从索引2开始删除0个元素,添加新元素
this.items.splice(2, 0, newItem)

// ✅ sort - 排序
this.items.sort((a, b) => a - b)

// ✅ reverse - 反转
this.items.reverse()

2. 非变异方法(需要重新赋值)

javascript 复制代码
// ❌ 错误 - 不会触发更新
this.items[0] = 'newValue'

// ✅ 正确 - 使用 Vue.set
this.$set(this.items, 0, 'newValue')

// ✅ 正确 - 使用 splice
this.items.splice(0, 1, 'newValue')

// ✅ 正确 - 修改长度
this.items.splice(newLength)  // 截断数组

3. 数组替换操作

javascript 复制代码
// 过滤数组
this.items = this.items.filter(item => item.id !== id)

// 映射数组
this.items = this.items.map(item => 
  item.id === id ? { ...item, value: 'updated' } : item
)

// 添加元素(非变异方式)
this.items = [...this.items, newItem]

// 合并数组
this.items = [...this.items, ...newItems]
复制代码
相关推荐
岳哥i4 小时前
vue鼠标单机复制文本
javascript
jacGJ5 小时前
记录学习--文件读写
java·前端·学习
毕设源码-赖学姐5 小时前
【开题答辩全过程】以 基于WEB的实验室开放式管理系统的设计与实现为例,包含答辩的问题和答案
前端
幻云20105 小时前
Python深度学习:从筑基到登仙
前端·javascript·vue.js·人工智能·python
我即将远走丶或许也能高飞7 小时前
vuex 和 pinia 的学习使用
开发语言·前端·javascript
钟离墨笺7 小时前
Go语言--2go基础-->基本数据类型
开发语言·前端·后端·golang
爱吃泡芙的小白白7 小时前
Vue 3 核心原理与实战:从响应式到企业级应用
前端·javascript·vue.js
卓怡学长8 小时前
m115乐购游戏商城系统
java·前端·数据库·spring boot·spring·游戏
码上成长8 小时前
JavaScript 数组合并性能优化:扩展运算符 vs concat vs 循环 push
开发语言·javascript·ecmascript
老陈聊架构8 小时前
『AI辅助Skill』掌握三大AI设计Skill:前端独立完成产品设计全流程
前端·人工智能·claude·skill