您好,欢迎访问一九零五行业门户网

vue实现全选反选方法总结

这次给大家带来vue实现全选反选方法总结,vue实现全选反选的注意事项有哪些,下面就是实战案例,一起来看一下。
全选功能可以说是前端开发中非常常见的一个功能,以前的项目开发用jquery开发比较多。最近在使用vue前端框架重构之前的项目。从jquery到vue的转变主要是一个思想想的转变,是将原有的直接操作dom的思想转变到操作数据,用数据驱动dom,也是vue框架的一个核心思想,思想转变过来,对功能的实现自然容易理解一些。
例如下面这个简单的demo
按照jquery的思想来做的话,要选中全选checkbox和所有的checkbox项,分别注册选中事件,判断选中状态来给相关的checkbox设置对应的状态,这就涉及到很多的dom操作。
下面就看一下vue数据驱动dom的思想来实现这一功能。
vue数据驱动dom实现功能
<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>
利用vue的双向数据绑定v-model命令,当勾选时,checkbox的value值会自动push到所绑定的数组checkdata中去,省去了不少对dom的操作。
如果是固定选项这样是可以实现的,但是这种方法有一些弊端,双向绑定数组数据是写死的,不太灵活,如果增加了checkbox选项,要更改wach里绑定数组的长度判断。
有时候checkbox选项也是后台动态获取过来的,这样也灵活一些。
例如后台数据是这样的:
ajaxdata: [{     name: 'a',     value: 'apple'   },{     name: 'b',     value: 'banana'   },{     name: 'c',     value: 'orange'   }]
需要先动态渲染checkbox选项,在进行数据绑定。
<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>
相信看了本文案例你已经掌握了方法,更多精彩请关注其它相关文章!
推荐阅读:
angular4的router属性使用案例详解
键值字符串如何转化为json字符串(附代码)
以上就是vue实现全选反选方法总结的详细内容。
其它类似信息

推荐信息