溫馨提示×

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

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

vue如何實(shí)現(xiàn)全選全不選

發(fā)布時(shí)間:2021-05-21 11:23:20 來(lái)源:億速云 閱讀:728 作者:小新 欄目:web開(kāi)發(fā)

這篇文章主要介紹了vue如何實(shí)現(xiàn)全選全不選,具有一定借鑒價(jià)值,感興趣的朋友可以參考下,希望大家閱讀完這篇文章之后大有收獲,下面讓小編帶著大家一起了解一下。

全選功能可以說(shuō)是前端開(kāi)發(fā)中非常常見(jiàn)的一個(gè)功能,以前的項(xiàng)目開(kāi)發(fā)用jQuery開(kāi)發(fā)比較多。最近在使用vue前端框架重構(gòu)之前的項(xiàng)目。從jQuery到vue的轉(zhuǎn)變主要是一個(gè)思想想的轉(zhuǎn)變,是將原有的直接操作dom的思想轉(zhuǎn)變到操作數(shù)據(jù),用數(shù)據(jù)驅(qū)動(dòng)dom,也是vue框架的一個(gè)核心思想,思想轉(zhuǎn)變過(guò)來(lái),對(duì)功能的實(shí)現(xiàn)自然容易理解一些。

例如下面這個(gè)簡(jiǎn)單的demo

vue如何實(shí)現(xiàn)全選全不選

按照jQuery的思想來(lái)做的話(huà),要選中全選checkbox和所有的checkbox項(xiàng),分別注冊(cè)選中事件,判斷選中狀態(tài)來(lái)給相關(guān)的checkbox設(shè)置對(duì)應(yīng)的狀態(tài),這就涉及到很多的dom操作。

下面就看一下vue數(shù)據(jù)驅(qū)動(dòng)dom的思想來(lái)實(shí)現(xiàn)這一功能。

vue數(shù)據(jù)驅(qū)動(dòng)dom實(shí)現(xiàn)功能

<div class="checkbox">
  <label for="quan">
    <!-- 這里的 $event 是將當(dāng)前對(duì)象傳入進(jìn)去,具體詳情請(qǐng)參照vue官方文檔 -->
    <input id="quan" type="checkbox" @click="checkAll($event)"> 全選
  </label>
  <label>
    <!-- v-model 雙向數(shù)據(jù)綁定命令 -->
    <input class="checkItem" type="checkbox" value="apple" v-model="checkData"> apple
  </label>
  <label>
    <input class="checkItem" type="checkbox" value="banana" v-model="checkData"> banana
  </label>
  <label>
    <input class="checkItem" type="checkbox" value="orange" v-model="checkData"> orange
  </label>
</div>
<script>
  new Vue({
    el: '#app',
    data(){
      return {
        checkData: [] // 雙向綁定checkbox數(shù)據(jù)數(shù)組
      }
    },
    watch: { // 監(jiān)視雙向綁定的數(shù)據(jù)數(shù)組
      checkData: {
        handler(){ // 數(shù)據(jù)數(shù)組有變化將觸發(fā)此函數(shù)
          if(this.checkData.length == 3){
            document.querySelector('#quan').checked = true;
          }else {
            document.querySelector('#quan').checked = false;
          }
        },
        deep: true // 深度監(jiān)視
      }
    },
    methods: {
      checkAll(e){ // 點(diǎn)擊全選事件函數(shù)
        var checkObj = document.querySelectorAll('.checkItem'); // 獲取所有checkbox項(xiàng)
        if(e.target.checked){ // 判定全選checkbox的勾選狀態(tài)
          for(var i=0;i<checkObj.length;i++){
            if(!checkObj[i].checked){ // 將未勾選的checkbox選項(xiàng)push到綁定數(shù)組中
              this.checkData.push(checkObj[i].value);
            }
          }
        }else { // 如果是去掉全選則清空checkbox選項(xiàng)綁定數(shù)組
          this.checkData = [];
        }
      }
    }
  });
</script>

利用vue的雙向數(shù)據(jù)綁定v-model命令,當(dāng)勾選時(shí),checkbox的value值會(huì)自動(dòng)push到所綁定的數(shù)組checkData中去,省去了不少對(duì)dom的操作。

如果是固定選項(xiàng)這樣是可以實(shí)現(xiàn)的,但是這種方法有一些弊端,雙向綁定數(shù)組數(shù)據(jù)是寫(xiě)死的,不太靈活,如果增加了checkbox選項(xiàng),要更改wach里綁定數(shù)組的長(zhǎng)度判斷。

有時(shí)候checkbox選項(xiàng)也是后臺(tái)動(dòng)態(tài)獲取過(guò)來(lái)的,這樣也靈活一些。

例如后臺(tái)數(shù)據(jù)是這樣的:

  ajaxData: [{
    name: 'a',
    value: 'apple'
  },{
    name: 'b',
    value: 'banana'
  },{
    name: 'c',
    value: 'orange'
  }]

需要先動(dòng)態(tài)渲染checkbox選項(xiàng),在進(jìn)行數(shù)據(jù)綁定。

<div id="app">
  <div class="checkbox">
    <label for="quan">
      <!-- 這里的 $event 是將當(dāng)前對(duì)象傳入進(jìn)去,具體詳情請(qǐng)參照vue官方文檔 -->
      <input id="quan" type="checkbox" @click="checkAll($event)"> 全選
    </label>
    <label v-for="item in ajaxData">
      <!-- v-model 雙向數(shù)據(jù)綁定命令 -->
      <input class="checkItem" type="checkbox" :value="item.value" v-model="checkData"> {{item.name}}
    </label>
  </div>
</div>
<script>
  new Vue({
    el: '#app',
    data(){
      return {
        ajaxData: [{ // 后臺(tái)請(qǐng)求過(guò)來(lái)的數(shù)據(jù)
          name: '選項(xiàng)1',
          value: 'apple'
        },{
          name: '選項(xiàng)2',
          value: 'banana'
        },{
          name: '選項(xiàng)3',
          value: 'orange'
        }],
        checkData: [] // 雙向數(shù)據(jù)綁定的數(shù)組
      }
    },
    watch: {
      checkData: { // 監(jiān)視雙向綁定的數(shù)組變化
        handler(){
          if(this.checkData.length == this.ajaxData.length){
            document.querySelector('#quan').checked = true;
          }else {
            document.querySelector('#quan').checked = false;
          }
        },
        deep: true
      }
    },
    methods: {
      checkAll(e){ // 點(diǎn)擊全選事件
        if(e.target.checked){
          this.ajaxData.forEach((el,i)=>{
            // 數(shù)組里沒(méi)有這一個(gè)value才push,防止重復(fù)push
            if(this.checkData.indexOf(el.value) == '-1'){ 
              this.checkData.push(el.value);
            }
          });
        }else { // 全不選選則清空綁定的數(shù)組
          this.checkData = [];
        }
      }
    }
  });
</script>

vue如何實(shí)現(xiàn)全選全不選

vue是什么

Vue是一套用于構(gòu)建用戶(hù)界面的漸進(jìn)式JavaScript框架,Vue與其它大型框架的區(qū)別是,使用Vue可以自底向上逐層應(yīng)用,其核心庫(kù)只關(guān)注視圖層,方便與第三方庫(kù)和項(xiàng)目整合,且使用Vue可以采用單文件組件和Vue生態(tài)系統(tǒng)支持的庫(kù)開(kāi)發(fā)復(fù)雜的單頁(yè)應(yīng)用。

感謝你能夠認(rèn)真閱讀完這篇文章,希望小編分享的“vue如何實(shí)現(xiàn)全選全不選”這篇文章對(duì)大家有幫助,同時(shí)也希望大家多多支持億速云,關(guān)注億速云行業(yè)資訊頻道,更多相關(guān)知識(shí)等著你來(lái)學(xué)習(xí)!

向AI問(wèn)一下細(xì)節(jié)

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

vue
AI