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>
相关推荐
JarvanMo几秒前
让 Flutter API 请求变得简单:http vs Dio — 你该如何选择?
前端
南北是北北几秒前
kotlin by lazy详解
前端·面试
用户8165111263972 分钟前
GCD源码剖析
前端
卓伊凡2 分钟前
复杂项目即时通讯从android 5升级android x后遗症之解决报错 #10 java.lang.NullPointerException-优雅草卓伊凡|
前端·后端
未来可期struggle3 分钟前
解决postcss-px-to-viewport-8-plugin 设置include不生效的问题
前端
Tetap4 分钟前
pixijs实现绿幕抠图和视频
前端·webgl
li理7 分钟前
鸿蒙Next Navigation路由终极指南:从基础到分布式路由实战
前端
li理9 分钟前
鸿蒙Next Navigation路由完全指南:从核心API到高级实战
前端
nppe621 分钟前
sequlize操作mysql小记
前端·后端
Moment30 分钟前
面试官:一个接口使用postman这些测试很快,但是页面加载很慢怎么回事 😤😤😤
前端·后端·面试