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防抖与节流
Nov 24 Vue.js
详解Vue 的异常处理机制
Nov 30 Vue.js
vue实现图片裁剪后上传
Dec 16 Vue.js
vue el-upload上传文件的示例代码
Dec 21 Vue.js
如何使用RoughViz可视化Vue.js中的草绘图表
Jan 30 Vue.js
用vite搭建vue3应用的实现方法
Feb 22 Vue.js
vue项目实现分页效果
Mar 24 Vue.js
vue3中的组件间通信
Mar 31 Vue.js
详解Vue的列表渲染
Nov 20 Vue.js
前端vue+express实现文件的上传下载示例
Feb 18 Vue.js
vue组件冲突之引用另一个组件出现组件不显示的问题
Apr 13 Vue.js
VUE递归树形实现多级列表
Jul 15 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
15种PHP Encoder的比较
2007/04/17 PHP
php继承的一个应用
2011/09/06 PHP
判断PHP数组是否为空的代码
2011/09/08 PHP
Zend Framework教程之配置文件application.ini解析
2016/03/10 PHP
php代码检查代理ip的有效性
2016/08/19 PHP
php模仿qq空间或朋友圈发布动态、评论动态、回复评论、删除动态或评论的功能(中)
2017/06/11 PHP
Laravel 手动开关 Eloquent 修改器的操作方法
2019/12/30 PHP
JS对象转换为Jquery对象实现代码
2013/12/29 Javascript
基于JQuery实现的图片自动进行缩放和裁剪处理
2014/01/31 Javascript
JavaScript正则表达式之multiline属性的应用
2015/06/16 Javascript
JS实现可拖曳、可关闭的弹窗效果
2015/09/26 Javascript
JS短信验证码倒计时功能的实现(没有验证码,只有倒计时)
2016/10/27 Javascript
微信小程序 loading 详解及实例代码
2016/11/09 Javascript
js微信扫描二维码登录网站技术原理
2016/12/01 Javascript
Bootstrap基本组件学习笔记之分页(12)
2016/12/08 Javascript
Bootstrap CSS组件之按钮组(btn-group)
2016/12/17 Javascript
JS实现定时任务每隔N秒请求后台setInterval定时和ajax请求问题
2017/10/15 Javascript
使用vue的v-for生成table并给table加上序号的实例代码
2017/10/27 Javascript
浅谈vue,angular,react数据双向绑定原理分析
2017/11/28 Javascript
JS运动改变单物体透明度的方法分析
2018/01/23 Javascript
node+vue实现文件上传功能
2020/05/28 Javascript
Python实现全角半角转换的方法
2014/08/18 Python
Python深入学习之对象的属性
2014/08/31 Python
零基础写python爬虫之使用urllib2组件抓取网页内容
2014/11/04 Python
初步解析Python下的多进程编程
2015/04/28 Python
Python 统计字数的思路详解
2018/05/08 Python
基于Python的一个自动录入表格的小程序
2020/08/05 Python
Python自动化测试中yaml文件读取操作
2020/08/20 Python
PyCharm 光标变成黑块的解决方式
2021/02/06 Python
解析HTML5中的新功能本地存储localStorage
2016/03/01 HTML / CSS
选购世界上最好的美妆品:Cult Beauty
2017/11/03 全球购物
农行实习自我鉴定
2013/09/22 职场文书
给面试官的感谢信
2014/02/01 职场文书
大学新闻系自荐书
2014/05/31 职场文书
施工工地安全标语
2014/06/07 职场文书
判缓刑人员个人思想汇报
2014/10/10 职场文书