溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

vue如何清空數(shù)組

發(fā)布時間:2021-12-29 12:37:49 來源:億速云 閱讀:1808 作者:小新 欄目:開發(fā)技術(shù)

小編給大家分享一下vue如何清空數(shù)組,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!

    1. 前言

    前兩天在工作當(dāng)中遇到一個問題,在vue3中使用reactive生成的響應(yīng)式數(shù)組如何清空,當(dāng)然我一般清空都是這么寫:

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

    不過這么用在reactive代理的方式中還是有點問題,比如這樣:

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

    很顯然,因為丟失了對原來響應(yīng)式對象的引用,這樣就直接失去了監(jiān)聽。

    2. 清空數(shù)據(jù)的幾種方式

    當(dāng)然,作為一名十年代碼經(jīng)驗常年摸魚的我,立馬就給出了幾個解決方案。

    2.1 使用ref()

    使用ref,這是最簡便的方法:

    const array = ref([1,2,3]);
    
        watch(array,()=>{
          console.log(array.value);
        },)
    
        array.value = [];

    vue如何清空數(shù)組

    2.2 使用slice

    slice顧名思義,就是對數(shù)組進行切片,然后返回一個新數(shù)組,感覺和go語言的切片有點類似。當(dāng)然用過react的小伙伴應(yīng)該經(jīng)常用slice,清空一個數(shù)組只需要這樣寫:

    const array = ref([1,2,3]);
    
        watch(array,()=>{
          console.log(array.value);
        },)
    
        array.value = array.value.slice(0,0);

    vue如何清空數(shù)組

    不過需要注意要使用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;

    而且,這種只會觸發(fā)一次,但是需要注意watch要開啟deep:

    vue如何清空數(shù)組

    不過,這種方式,使用reactive會更加方便,也不用開啟deep:

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

    vue如何清空數(shù)組

    2.4 使用splice

    副作用函數(shù)splice也是一種方案,這種情況同時也可以使用reactive:

    const array = reactive([1,2,3]);
    
        watch(()=>[...array],()=>{
          console.log(array);
        },)
    
        array.splice(0,array.length)

    不過要注意,watch會觸發(fā)多次:

    vue如何清空數(shù)組

    當(dāng)然也可以使用ref,但是注意這種情況下,需要開啟deep:

    const array = ref([1,2,3]);
    
        watch(array,()=>{
          console.log(array.value);
        },{
          deep:true
        })
    
        array.value.splice(0,array.value.length)

    vue如何清空數(shù)組

    但是可以看到ref也和reactive一樣,會觸發(fā)多次。

    以上是“vue如何清空數(shù)組”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注億速云行業(yè)資訊頻道!

    向AI問一下細節(jié)

    免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

    vue
    AI