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]
复制代码
相关推荐
xiaotao1313 小时前
第九章:Vite API 参考手册
前端·vite·前端打包
午安~婉3 小时前
Electron桌面应用聊天(续)
前端·javascript·electron
彧翎Pro4 小时前
基于 RO1 noetic 配置 robosense Helios 32(速腾) & xsense mti 300
前端·jvm
小码哥_常4 小时前
解锁系统设置新姿势:Activity嵌入全解析
前端
之歆4 小时前
前端存储方案对比:Cookie-Session-LocalStorage-IndexedDB
前端
哟哟耶耶4 小时前
vue3-单文件组件css功能(:deep,:slotted,:global,useCssModule,v-bind)
前端·javascript·css
是罐装可乐4 小时前
深入理解“句柄(Handle)“:从浏览器安全到文件系统访问
前端·javascript·安全
华科易迅4 小时前
Vue如何集成封装Axios
前端·javascript·vue.js
康一夏4 小时前
Next.js 13变化有多大?
前端·react·nextjs
糖炒栗子03264 小时前
前端项目标准环境搭建与启动
前端