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>
相关推荐
与光_同尘几秒前
一个隐蔽的 DOM 陷阱:id="nodeName" 引发的血案
前端
雲墨款哥1 分钟前
React小demo,评论列表
前端·react.js
青瓜达利园2 分钟前
zustand 入门
前端
triumph_passion4 分钟前
Tailwind CSS v4 深度指南:目录架构与主题系统
前端·css
UIUV5 分钟前
React表单处理:受控组件与非受控组件全面解析
前端·javascript·react.js
henry7 分钟前
React Native 横向滚动指示器组件库(淘宝|京东...&旧版|新版)
前端
一只爱吃糖的小羊7 分钟前
JSBridge 传参陷阱:h5明明传了参数,安卓却收到为空
前端·javascript
实习生小黄10 分钟前
window.print 实现简单打印
前端·javascript
Wect12 分钟前
LeetCode 26.删除有序数组中的重复项:快慢指针的顺势应用
前端·typescript