Vue3 重置&覆盖 reactive 数组数据的方法

核心要点:
  • 通过splice删除原数组内的所有数据,并添加新的数据进去。
  • 潜在影响:大数据量下,splice重置数组和 ref 的.value重新赋值重置数组,哪个耗时短还需自行测试。

通过 `splice` 传入0 和 Infinity 来删除原数组从头到尾的内容,然后`...[]`将新数据丢进响应式数组里。

html 复制代码
<template>
  <button @click="c2()">测试按钮</button>
</template>

<script setup lang="ts">
import { reactive, watch } from 'vue'
const arr1 = reactive([1,2,3,4])
watch(arr1,(val)=>{
  console.log(...val);
})
function c2() {
  arr1.push(arr1.length+1)
}

setTimeout(() => {
  arr1.splice(0,Infinity,...[11,22,33,44])
}, 6000);

</script>
相关推荐
行走的陀螺仪18 小时前
JavaScript 装饰器完全指南(原理/分类/场景/实战/兼容)
开发语言·javascript·ecmascript·装饰器
瘦的可以下饭了18 小时前
3 链表 二叉树
前端·javascript
我那工具都齐_明早我过来上班18 小时前
WebODM生成3DTiles模型在Cesium地图上会垂直显示问题解决(y-up-to-z-up)
前端·gis
粉末的沉淀18 小时前
jeecgboot:electron桌面应用打包
前端·javascript·electron
1024肥宅18 小时前
浏览器相关 API:DOM 操作全解析
前端·浏览器·dom
烟西19 小时前
手撕React18源码系列 - Event-Loop模型
前端·javascript·react.js
空镜19 小时前
通用组件使用文档
前端·javascript
前端小张同学19 小时前
餐饮小程序需要你们
java·前端·后端