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>
相关推荐
你真的可爱呀6 分钟前
自定义颜色选择功能
开发语言·前端·javascript
小王和八蛋10 分钟前
JS中 escape urlencodeComponent urlencode 区别
前端·javascript
奔跑的web.11 分钟前
TypeScript类型系统核心速通:从基础到常用复合类型包装类
开发语言·前端·javascript·typescript·vue
Misnice11 分钟前
Webpack、Vite 、Rsbuild 区别
前端·webpack·node.js
Kagol15 分钟前
🎉历时1年,TinyEditor v4.0 正式发布!
前端·typescript·开源
丶一派胡言丶15 分钟前
02-VUE介绍和指令
前端·javascript·vue.js
C_心欲无痕17 分钟前
网络相关 - 跨域解决方式
前端·网络
天蓝色的鱼鱼18 分钟前
Vue开发必考:defineComponent与defineAsyncComponent,你真的掌握吗?
前端·vue.js
用户812748281512019 分钟前
aosp14分屏分割线区域部分深入剖析-framework实战干货
前端
三小河20 分钟前
内网环境下 Web 离线地图的实现方案与合规性探讨
前端