JavaScript清空数组的四种方法

 更新时间:2024年03月20日 09:58:38   作者:CRMEB  
这篇文章主要介绍了JavaScript清空数组的四种方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

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、总结

到此这篇关于JavaScript清空数组的四种方法的文章就介绍到这了,更多相关JavaScript清空数组内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 学习Bootstrap组件之下拉菜单

    学习Bootstrap组件之下拉菜单

    本文介绍了一款基于HTML,CSS,JAVASCRIPT的简洁灵活的流行前端框架,需要了解的朋友可以参考下
    2015-07-07
  • 微信小程序实现折叠展开效果

    微信小程序实现折叠展开效果

    这篇文章主要为大家详细介绍了微信小程序实现折叠展开效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2018-07-07
  • javascript数组常见操作方法实例总结【连接、添加、删除、去重、排序等】

    javascript数组常见操作方法实例总结【连接、添加、删除、去重、排序等】

    这篇文章主要介绍了javascript数组常见操作方法,结合实例形式总结分析了javascript数组的连接、添加、删除、去重、排序等操作,代码注释附带较为详细的说明,需要的朋友可以参考下
    2019-06-06
  • 使用JavaScript下载图片并保存到本地的详细解释和代码示例

    使用JavaScript下载图片并保存到本地的详细解释和代码示例

    在前端开发中经常会遇到需要将图片从网络上下载并保存到本地的需求,这篇文章主要给大家介绍了关于使用JavaScript下载图片并保存到本地的详细解释和代码示例,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2024-07-07
  • JavaScript流程控制语句实例详解

    JavaScript流程控制语句实例详解

    JavaScript中的流程控制语句是编写复杂逻辑和控制程序执行顺序的关键元素,这篇文章主要介绍了JavaScript流程控制语句的相关资料,文中通过代码介绍的非常详细,需要的朋友可以参考下
    2025-12-12
  • JavaScript中的eval()函数使用介绍

    JavaScript中的eval()函数使用介绍

    这篇文章主要介绍了JavaScript中的eval()函数使用介绍,本文讲解了eval()的使用、eval()的返回值、变量环境(variable environment)等内容,需要的朋友可以参考下
    2014-12-12
  • three.js载入常用类型3D模型的几种方法

    three.js载入常用类型3D模型的几种方法

    通过Three.js的材质和几何体,我们可以很方便的创建基础3D模型,下面这篇文章主要给大家介绍了关于three.js载入常用类型3D模型的几种方法,需要的朋友可以参考下
    2024-04-04
  • 基于JavaScript实现在线PDF压缩工具

    基于JavaScript实现在线PDF压缩工具

    这篇文章主要为大家详细介绍了如何基于JavaScript实现在线PDF压缩工具,整体思路是优先处理 PDF 内已经存在的 JPEG 图片资源,再把处理后的内容重新保存成新的 PDF 文件,感兴趣的小伙伴可以了解下
    2026-04-04
  • Javascript中浮点数相乘的一个解决方法

    Javascript中浮点数相乘的一个解决方法

    这篇文章主要介绍了Javascript中浮点数相乘的一个解决方法,需要的朋友可以参考下
    2014-06-06
  • JS双击变input框批量修改内容

    JS双击变input框批量修改内容

    这篇文章主要介绍了JS双击变input框批量修改内容的实现代码,非常不错,具有参考借鉴价值,需要的朋友可以参考下
    2016-12-12

最新评论