广告
返回顶部
首页 > 资讯 > 前端开发 > JavaScript >vue清空数组的几个方式(小结)
  • 197
分享到

vue清空数组的几个方式(小结)

2024-04-02 19:04:59 197人浏览 泡泡鱼
摘要

目录1. 前言 2. 清空数据的几种方式 2.1 使用ref() 2.2 使用slice 2.3 length赋值为0 2.4 使用splice 3. 总结 1. 前言 前两天在工

1. 前言

前两天在工作当中遇到一个问题,在vue3中使用Reactive生成的响应式数组如何清空,当然我一般清空都是这么写:


  let array = [1,2,3];
  array = [];

不过这么用在reactive代理的方式中还是有点问题,比如这样:


    let array = reactive([1,2,3]);
    watch(()=>[...array],()=>{
      console.log(array);
    },)
    array = reactive([]);

很显然,因为丢失了对原来响应式对象的引用,这样就直接失去了监听。

2. 清空数据的几种方式

当然,作为一名十年代码经验常年摸鱼的我,立马就给出了几个解决方案。

2.1 使用ref()

使用ref,这是最简便的方法:


    const array = ref([1,2,3]);

    watch(array,()=>{
      console.log(array.value);
    },)

    array.value = [];

2.2 使用slice

slice顾名思义,就是对数组进行切片,然后返回一个新数组,感觉和Go语言的切片有点类似。当然用过react的小伙伴应该经常用slice,清空一个数组只需要这样写:


    const array = ref([1,2,3]);

    watch(array,()=>{
      console.log(array.value);
    },)

    array.value = array.value.slice(0,0);

不过需要注意要使用ref。

2.3 length赋值为0

个人比较喜欢这种,直接将length赋值为0:


    const array = ref([1,2,3]);

    watch(array,()=>{
      console.log(array.value);
    },{
      deep:true
    })

   array.value.length = 0;

而且,这种只会触发一次,但是需要注意watch要开启deep:

不过,这种方式,使用reactive会更加方便,也不用开启deep:


    const array = reactive([1,2,3]);

    watch(()=>[...array],()=>{
      console.log(array);
    })

    array.length = 0;

2.4 使用splice

副作用函数splice也是一种方案,这种情况同时也可以使用reactive:


    const array = reactive([1,2,3]);

    watch(()=>[...array],()=>{
      console.log(array);
    },)

    array.splice(0,array.length)

不过要注意,watch会触发多次:

当然也可以使用ref,但是注意这种情况下,需要开启deep:


    const array = ref([1,2,3]);

    watch(array,()=>{
      console.log(array.value);
    },{
      deep:true
    })

    array.value.splice(0,array.value.length)

但是可以看到ref也和reactive一样,会触发多次。

3. 总结

到此这篇关于Vue清空数组的几个方式(小结)的文章就介绍到这了,更多相关vue清空数组内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

--结束END--

本文标题: vue清空数组的几个方式(小结)

本文链接: https://www.lsjlt.com/news/161154.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作