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


Posted in Vue.js onNovember 17, 2020

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

<template>
 <div class="visiblePeople">
 <topbar />
 <ul class="list clear_float">
 <li v-for="(item, index) in people" :key="index">
 <van-checkbox
  v-model="item.flag"
  class="listli"
 ></van-checkbox>
 <div class="right">
  <p>{{ item.name }}</p>
  <p>{{ item.id }}</p>
 </div>
 </li>
 </ul>
 <div class="bottom">
 <div class="left">
 <van-checkbox v-model="allcheck" class="all">全选</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实战教程》

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Vue.js 相关文章推荐
在vue中通过render函数给子组件设置ref操作
Nov 17 Vue.js
Vue项目利用axios请求接口下载excel
Nov 17 Vue.js
对vue生命周期的深入理解
Dec 03 Vue.js
Vue 组件注册全解析
Dec 17 Vue.js
Vue中inheritAttrs的使用实例详解
Dec 31 Vue.js
vue组件是如何解析及渲染的?
Jan 13 Vue.js
vue-cli 3如何使用vue-bootstrap-datetimepicker日期插件
Feb 20 Vue.js
vue3.0中使用element的完整步骤
Mar 04 Vue.js
vue响应式原理与双向数据的深入解析
Jun 04 Vue.js
vue如何实现关闭对话框后刷新列表
Apr 08 Vue.js
vue实现登陆页面开发实践
May 30 Vue.js
vue如何在data中引入图片的正确路径
Jun 05 Vue.js
vue中音频wavesurfer.js的使用方法
Feb 20 #Vue.js
vue+vant实现购物车全选和反选功能
Nov 17 #Vue.js
在vue中通过render函数给子组件设置ref操作
Nov 17 #Vue.js
vue+iview分页组件的封装
Nov 17 #Vue.js
快速解决vue2+vue-cli3项目ie兼容的问题
Nov 17 #Vue.js
vue+iview实现分页及查询功能
Nov 17 #Vue.js
vue中echarts的用法及与elementui-select的协同绑定操作
Nov 17 #Vue.js
You might like
php中使用Akismet防止垃圾评论的代码
2011/06/10 PHP
php开发文档 会员收费1期
2012/08/14 PHP
ThinkPHP3.1新特性之多层MVC的支持
2014/06/19 PHP
关于URL最大长度限制的相关资料查证
2014/12/23 PHP
基于PHP+jQuery+MySql实现红蓝(顶踩)投票代码
2015/08/25 PHP
JQuery 小练习(实例代码)
2009/08/07 Javascript
javaScript 利用闭包模拟对象的私有属性
2011/12/29 Javascript
caller和callee的区别介绍及演示结果
2013/03/10 Javascript
JavaScript获取表格(table)当前行的值、删除行、增加行
2015/07/03 Javascript
JS HTML5实现拖拽移动列表效果
2020/08/27 Javascript
Angularjs使用ng-repeat中$even和$odd属性的注意事项
2016/12/31 Javascript
vue.js实现刷新当前页面的方法教程
2017/07/05 Javascript
javascript中的replace函数(带注释demo)
2018/01/07 Javascript
Angular6中使用Swiper的方法示例
2018/07/09 Javascript
在vue中使用echarts图表实例代码详解
2018/10/22 Javascript
vue使用transition组件动画效果的实例代码
2021/01/28 Vue.js
Python ldap实现登录实例代码
2016/09/30 Python
老生常谈Python基础之字符编码
2017/06/14 Python
对python字典元素的添加与修改方法详解
2018/07/06 Python
pandas对dataFrame中某一个列的数据进行处理的方法
2019/07/08 Python
python并发编程多进程 互斥锁原理解析
2019/08/20 Python
python实现的读取网页并分词功能示例
2019/10/29 Python
python使用正则表达式去除中文文本多余空格,保留英文之间空格方法详解
2020/02/11 Python
关于Tensorflow 模型持久化详解
2020/02/12 Python
python如何调用字典的key
2020/05/25 Python
Python模拟登录requests.Session应用详解
2020/11/17 Python
python爬虫beautifulsoup解析html方法
2020/12/07 Python
美国战术品牌:5.11 Tactical
2019/05/01 全球购物
党员大会主持词
2014/04/02 职场文书
大学生社会实践方案
2014/05/11 职场文书
2015年安全生产工作总结范文
2015/04/02 职场文书
2016三八妇女节慰问信
2015/11/30 职场文书
有关信念的名言语录集锦
2019/12/06 职场文书
ant design vue的form表单取值方法
2022/06/01 Vue.js
详解Spring Bean的配置方式与实例化
2022/06/10 Java/Android
CSS使用SVG实现动态分布的圆环发散路径动画
2022/12/24 HTML / CSS