php 全选 反选,利用vue实现全选反选功能

这次给大家带来利用vue实现全选反选功能,利用vue实现全选反选功能的注意事项有哪些,下面就是实战案例,一起来看一下。

全选功能可以说是前端开发中非常常见的一个功能,以前的项目开发用jQuery开发比较多。最近在使用vue前端框架重构之前的项目。从jQuery到vue的转变主要是一个思想想的转变,是将原有的直接操作dom的思想转变到操作数据,用数据驱动dom,也是vue框架的一个核心思想,思想转变过来,对功能的实现自然容易理解一些。

例如下面这个简单的demo

dbf9bfd00e24db1596e3c5e574eb8118.png

按照jQuery的思想来做的话,要选中全选checkbox和所有的checkbox项,分别注册选中事件,判断选中状态来给相关的checkbox设置对应的状态,这就涉及到很多的dom操作。

下面就看一下vue数据驱动dom的思想来实现这一功能。

vue数据驱动dom实现功能

全选

apple

banana

orange

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

if(!checkObj[i].checked){ // 将未勾选的checkbox选项push到绑定数组中

this.checkData.push(checkObj[i].value);

}

}

}else { // 如果是去掉全选则清空checkbox选项绑定数组

this.checkData = [];

}

}

}

});

利用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选项,在进行数据绑定。

全选

{{item.name}}

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 = [];

}

}

}

});

d0ff126e53125b0bc602a36f70d5710e.png

方法并不是最优的写法,也存在一些弊端,欢迎各位指点迷津,一起探讨。

相信看了本文案例你已经掌握了方法,更多精彩请关注php中文网其它相关文章!

推荐阅读:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Vue 3 中实现全选反选功能,可以使用 `v-model` 指令绑定一个布尔值来实现全选反选的状态切换。具体实现步骤如下: 1. 在 data 中定义一个数组 `items`,用来存储需要全选反选的选项列表。 ```javascript <script> export default { data() { return { items: [ { id: 1, name: '选项1', checked: false }, { id: 2, name: '选项2', checked: false }, { id: 3, name: '选项3', checked: false } ], allChecked: false // 全选状态,默认为未选中 } } } </script> ``` 2. 在模板中使用 `v-for` 循环渲染出所有选项,并使用 `v-model` 绑定每个选项的 `checked` 属性。 ```html <template> <div> <label> <input type="checkbox" v-model="allChecked" @change="selectAll"> 全选 </label> <div v-for="item in items" :key="item.id"> <label> <input type="checkbox" v-model="item.checked" @change="checkItem"> {{ item.name }} </label> </div> </div> </template> ``` 3. 实现全选反选的方法。 ```javascript <script> export default { data() { return { items: [ { id: 1, name: '选项1', checked: false }, { id: 2, name: '选项2', checked: false }, { id: 3, name: '选项3', checked: false } ], allChecked: false // 全选状态,默认为未选中 } }, methods: { // 全选/取消全选 selectAll() { this.items.forEach(item => item.checked = this.allChecked) }, // 单个选项被选中/取消选中 checkItem() { this.allChecked = this.items.every(item => item.checked) } } } </script> ``` 在 `selectAll` 方法中,遍历 `items` 数组,将每个选项的 `checked` 属性设置为 `allChecked` 的值,这样就实现全选和取消全选功能。 在 `checkItem` 方法中,判断当前是否所有的选项都被选中,如果是,则将 `allChecked` 的值设置为 `true`,否则设置为 `false`,这样就实现反选功能。 这样,我们就完成了 Vue 3 中全选反选实现
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值