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>
相关推荐
gxf52030880698814 分钟前
Flutter 裁剪图片
前端·app
半岛@少年29 分钟前
都是JS,CJS和ESM有什么区别?
javascript·esm·前端模块化·cjs
想吃火锅100530 分钟前
【leetcode】165.比较版本号js
javascript·算法·leetcode
ITMan彪叔31 分钟前
赋能UE运行态编辑平台: 网络图片下载的插件改造与复盘
前端
RANxy35 分钟前
🚀 Umi Max 项目从0到1:企业级 React 脚手架实战
前端·前端框架
拾年2751 小时前
深入理解 V8 引擎:从代码执行到垃圾回收的完整链路
前端·javascript·v8
Master_Azur1 小时前
javaScript进阶
前端
markfeng81 小时前
React入门教学
前端·react.js
ze_juejin1 小时前
Object.defineProperty vs Proxy 对比总结
前端
卤蛋fg61 小时前
高性能 Vue 甘特图:vxe-gantt 如何秒级渲染万级任务数据
vue.js