Maison  >  Article  >  interface Web  >  Utilisez vue pour implémenter la fonction all-select et invert-select

Utilisez vue pour implémenter la fonction all-select et invert-select

php中世界最好的语言
php中世界最好的语言original
2018-04-20 16:38:063273parcourir

Cette fois, je vais vous apporter les précautions sur la façon d'utiliser vue pour implémenter les fonctions select-all et invert-select. Ce qui suit est un cas pratique.

La fonction select all peut être considérée comme une fonction très courante dans le développement front-end. Dans le passé, jQuery était principalement utilisé dans le développement de projets. Récemment, je refactorisais mon projet précédent en utilisant le framework front-end Vue. La transition de jQuery vers Vue est principalement un changement de pensée. Il s'agit de transformer l'idée originale d'exploiter directement le DOM en données d'exploitation. L'utilisation de données pour piloter le DOM est également une idée centrale du framework Vue. la réflexion mènera à la réalisation de fonctions naturellement plus faciles à comprendre.

Par exemple, la démo simple suivante

Si vous le faites selon l'idée de jQuery, vous devez cochez la case Sélectionner tout et toutes les cases à cocher, enregistrez les événements sélectionnés respectivement, déterminez le statut sélectionné pour définir le statut correspondant pour la case à cocher appropriée, ce qui implique de nombreuses opérations dom.

Jetons un coup d'œil à l'idée de vue data-driven dom pour implémenter cette fonction.

Fonction d'implémentation dom basée sur les données de vue

<p class="checkbox">
  <label for="quan">
    <!-- 这里的 $event 是将当前对象传入进去,具体详情请参照vue官方文档 -->
    <input id="quan" type="checkbox" @click="checkAll($event)"> 全选
  </label>
  <label>
    <!-- v-model 双向数据绑定命令 -->
    <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>
</p>
<script>
  new Vue({
    el: '#app',
    data(){
      return {
        checkData: [] // 双向绑定checkbox数据数组
      }
    },
    watch: { // 监视双向绑定的数据数组
      checkData: {
        handler(){ // 数据数组有变化将触发此函数
          if(this.checkData.length == 3){
            document.querySelector('#quan').checked = true;
          }else {
            document.querySelector('#quan').checked = false;
          }
        },
        deep: true // 深度监视
      }
    },
    methods: {
      checkAll(e){ // 点击全选事件函数
        var checkObj = document.querySelectorAll('.checkItem'); // 获取所有checkbox项
        if(e.target.checked){ // 判定全选checkbox的勾选状态
          for(var i=0;i<checkObj.length;i++){
            if(!checkObj[i].checked){ // 将未勾选的checkbox选项push到绑定数组中
              this.checkData.push(checkObj[i].value);
            }
          }
        }else { // 如果是去掉全选则清空checkbox选项绑定数组
          this.checkData = [];
        }
      }
    }
  });
</script>

À l'aide de la commande v-model de liaison de données bidirectionnelle de vue, lorsqu'elle est cochée, la valeur de la case à cocher sera automatiquement Poussez-le dans le tableau lié checkData, ce qui permet d'économiser de nombreuses opérations sur le dom.

S'il s'agit d'une option fixe, cela peut être réalisé, mais cette méthode présente certains inconvénients. La liaison bidirectionnelle des données du tableau est codée en dur et peu flexible. Si l'option de case à cocher est ajoutée, la liaison. dans lequel doit être modifié. Déterminez la longueur du tableau.

Parfois, l'option de case à cocher est obtenue dynamiquement à partir de l'arrière-plan, ce qui est plus flexible.

Par exemple, les données d'arrière-plan ressemblent à ceci :

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

Vous devez d'abord restituer dynamiquement l'option de case à cocher, puis effectuer la liaison de données. La méthode

<p id="app">
  <p class="checkbox">
    <label for="quan">
      <!-- 这里的 $event 是将当前对象传入进去,具体详情请参照vue官方文档 -->
      <input id="quan" type="checkbox" @click="checkAll($event)"> 全选
    </label>
    <label v-for="item in ajaxData">
      <!-- v-model 双向数据绑定命令 -->
      <input class="checkItem" type="checkbox" :value="item.value" v-model="checkData"> {{item.name}}
    </label>
  </p>
</p>
<script>
  new Vue({
    el: '#app',
    data(){
      return {
        ajaxData: [{ // 后台请求过来的数据
          name: '选项1',
          value: 'apple'
        },{
          name: '选项2',
          value: 'banana'
        },{
          name: '选项3',
          value: 'orange'
        }],
        checkData: [] // 双向数据绑定的数组
      }
    },
    watch: {
      checkData: { // 监视双向绑定的数组变化
        handler(){
          if(this.checkData.length == this.ajaxData.length){
            document.querySelector('#quan').checked = true;
          }else {
            document.querySelector('#quan').checked = false;
          }
        },
        deep: true
      }
    },
    methods: {
      checkAll(e){ // 点击全选事件
        if(e.target.checked){
          this.ajaxData.forEach((el,i)=>{
            // 数组里没有这一个value才push,防止重复push
            if(this.checkData.indexOf(el.value) == '-1'){ 
              this.checkData.push(el.value);
            }
          });
        }else { // 全不选选则清空绑定的数组
          this.checkData = [];
        }
      }
    }
  });
</script>

n'est pas la manière optimale d'écrire, et elle présente également certains inconvénients. Vous êtes invités à nous donner quelques conseils et à en discuter ensemble.

Je pense que vous maîtrisez la méthode après avoir lu le cas dans cet article. Pour des informations plus intéressantes, veuillez prêter attention aux autres articles connexes sur le site Web chinois de php !

Lecture recommandée :

vue.js+element-ui tree control modifié les étapes iview explication détaillée

Yuansheng JS implémente événement de glissement de fichier

cas de l'arborescence des fichiers vue

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn