加入收藏 | 设为首页 | 会员中心 | 我要投稿 云计算网_泰州站长网 (http://www.0523zz.com/)- 视觉智能、AI应用、CDN、行业物联网、智能数字人!
当前位置: 首页 > 综合聚焦 > 创业热点 > 点评 > 正文

vue使用vant中的checkbox实现全选功能

发布时间:2020-11-22 21:12:43 所属栏目:点评 来源:网络整理
导读:短视频,自媒体,达人种草一站服务 这篇文章主要为大家详细介绍了vue使用vant中的checkbox实现全选功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下 本文实例为大家分享了vue使用vant中的checkbox实现全选功能的具体

  短视频,自媒体,达人种草一站服务

这篇文章主要为大家详细介绍了vue使用vant中的checkbox实现全选功能,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

本文实例为大家分享了vue使用vant中的checkbox实现全选功能的具体代码,供大家参考,具体内容如下

<template>
<div>
<topbar />
<ul>
<li v-for="(item, index) in people" :key="index">
<van-checkbox
v-model="item.flag"

></van-checkbox>
<div>
<p>{{ item.name }}</p>
<p>{{ item.id }}</p>
</div>
</li>
</ul>
<div>
<div>
<van-checkbox v-model="allcheck">全选</van-checkbox>
</div>
<button @click="jump">确定</button>
</div>
</div>
</template>

<script>
export default {
data() {
return {
people: [
{ id: "002", name: "陈阳", flag: true },
{
id: "003",
name: "王苗苗",
flag: true,
},
{
id: "004",
name: "张梁俊",
flag: true,
},
{
id: "005",
name: "刘路",
flag: true,
},
],
};
},
methods: {
//点击确定后跳转回新增合同页面
jump() {
this.$router.push("/addContract");
},
//单选按钮切换
// change(index) {
// this.people[index].flag = !this.people[index].flag;
// console.log(this.people[index].flag);
// },
},
computed:{
allcheck:{
get(){
//取值
//every方法,数组中每一项都满足一个条件返回true
return this.people.every(item=>item.flag)
},
set(newValue){
//设置值
console.log('触发set方法')
this.people.map(item=>item.flag=newValue)
}
},
filterAll(){
return this.people.filter(item=>item.flag).length
},
count(){
let checkedList=this.people.filter(item=>item.flag)
return checkedList.length.reduce((total,item)=>{
return total+item.num
},0)
}
}
};
</script>
<style lang="less" scoped>
.list {
background: #f8f9fb;
height: 574px;
li {
height: 56px;
margin: 10px 0 10px 0;
float: left;
img {
width: 19px;
height: 19px;
float: left;
margin: 13px;
&.on {
display: block;
}
&.off {
display: none;
}
}
.listli {
float: left;
margin: 19px 13px 0 13px;
}
.right {
float: left;
background: #ffffff;
width: 328px;
height: 56px;
padding: 0px 0 0 13px;
box-sizing: border-box;
p:nth-of-type(1) {
font-size: 15px;
font-family: PingFang SC;
font-weight: 400;
color: #000000;
line-height: 29px;
}
p:nth-of-type(2) {
font-size: 13px;
font-family: PingFang SC;
font-weight: 400;
color: #666666;
line-height: 14px;
}
}
}
}
.bottom {
height: 50px;
position: fixed;
bottom: 0;
.left {
width: 237px;
background: #ffffff;
height: 100%;
float: left;
img {
width: 18px;
float: left;
margin: 18px 13px 0 18px;
&.on {
display: block;
}
&.off {
display: none;
}
}
.all {
margin: 17px 0 0 14px;
}
p {
float: left;
font-size: 13px;
font-family: PingFang SC;
font-weight: 400;
color: #333333;
margin-top: 18px;
}
}
button {
float: left;
width: 138px;
height: 50px;
line-height: 50px;
background: #336afa;
color: #ffffff;
}
}
</style>

本次遇到的问题是自己一开始没发现在people数组里面,定义的每一项flag的值设置的类型为字符串型即flag="true",导致一开始进入页面全部无论值为true还是false,复选框都是选中效果,修改之后便没有了此问题。

关于vue.js组件的教程,请大家点击专题vue.js组件学习教程进行学习。

更多vue学习教程请阅读专题《vue实战教程》

(编辑:云计算网_泰州站长网)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读