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>
相关推荐
2501_944446002 分钟前
Flutter&OpenHarmony文本输入组件开发
前端·javascript·flutter
小圣贤君8 分钟前
小说地图设计:Canvas 油漆桶工具的实现之旅
vue.js·electron·写作·小说地图·油漆桶
AI前端老薛8 分钟前
你了解react合成事件吗
前端·react.js·前端框架
WebRuntime16 分钟前
所有64位WinForm应用都是Chromium浏览器(2)
javascript·c#·.net·web
贺今宵18 分钟前
2025.electron-vue3-sqlite3使用
前端·javascript·electron
王同学_11636 分钟前
爬虫辅助技术(css选择器、xpath、正则基础语法)
前端·css·爬虫
Irene199139 分钟前
创建新DOM节点方式总结
javascript·dom
2501_946233891 小时前
Flutter与OpenHarmony大师详情页面实现
android·javascript·flutter
牛先森家的牛奶1 小时前
elementUI的table合并行和列模板
前端·javascript·elementui
En^_^Joy1 小时前
CSS常用属性速查手册
前端·css