vuejs实现全选功能
2021-03-14 02:27
阅读:473
全选功能
开发说明
- 项目使用 vuejs 实现
- 项目提供两种方式实现全选功能,并附上源码,共参考
方式一
方式一,完全发挥了 vuejs 的特性,使用了 computed 实现了对 单选按钮的实时监控。
-
var list = [
{
title : ‘数据一‘,
checked : false,
},{
title : ‘数据二‘,
checked : true,
},{
title : ‘数据三‘,
checked : true,
},{
title : ‘数据四‘,
checked : true,
},{
title : ‘数据五‘,
checked : true,
}];
var vm = new Vue({
el : ‘#app‘,
data:{
list
},
computed:{
status:{
get(){
return this.list.filter( item => item.checked ).length === this.list.length
},
set( value ){
this.list.map(function( item ){
item.checked = value;
return item;
});
}
}
}
});
方式二
方式二使用普通的事件监听方式处理数据状态
-
var list = [
{
title : ‘数据一‘,
checked : false,
},{
title : ‘数据二‘,
checked : true,
},{
title : ‘数据三‘,
checked : true,
},{
title : ‘数据四‘,
checked : true,
},{
title : ‘数据五‘,
checked : true,
}];
var vm = new Vue({
el : ‘#app‘,
data : {
list,
status : this.list.filter( item => item.checked ).length === this.list.length ? true : false
},
methods : {
allCheck(){
this.list.map(function( item ){
item.checked = this.status;
return item;
}.bind(this));
},
singleCheck(){
this.status = this.list.filter( item => item.checked ).length === this.list.length ? true : false
}
}
});
说明在方式二中使用了事件监听函数,使用了change,也可以使用 click,使用click事件时,低版本的vuejs存在 bug,高版本中 bug 修复,bug 存在于,在双向绑定状态改变时 使用click数据状态后滞后。
评论
亲,登录后才可以留言!