vue使用监听实现全选反选功能


Posted in Javascript onJuly 06, 2018

最近在学习vue这一块的内容,在项目中用到了全选全不选的功能,开始的时候借鉴了别人写的功能,但感觉写的有一些缺陷,然后就自己写了一套,如有写的不好的地方,请各位大佬指教,废话不多说,上代码。

首先定义数据

data: {
   /*全选、全不选*/
   allCheck:false,//全选功能
   //循环数据
   checkArr:[
     {cityName:"东城区",isCheck:false},
     {cityName:"西城区",isCheck:false},
     {cityName:"朝阳区",isCheck:false},
     {cityName:"丰台区",isCheck:false},
   ],
}

然后是页面代码:

<div>
   <div v-for="carType in checkArr">
     <p>
       <input type="checkbox" v-model="carType.isCheck"/>
       <a href="javascript:void(0)" rel="external nofollow" >{{carType.typeName}}</a>
    </p>
   </div>
</div>
<div>
  <input type="checkbox" id="chooseAllType" v-model="allCheck" @click="selectAll(allCheck)"/>
  全选
</div>

下面是js中代码

methods: {
  /*点击全选,选中所有复选框*/
  selectAll: function (data) {
    var _this = this;
    //如果父级被选中,那么子集循环,全被给checked=true
    if (!data) {
      _this.checkArr.forEach(function (item) {
        item.isCheck = true;
      });
    } else {
      //相反,如果没有被选中,子集应该全部checked=false
      _this.checkArr.forEach(function (item) {
        item.isCheck = false;
      });
    }
  },
}

下面是监听部分代码,主要功能为如果子集全部选中,全选按钮同样被勾选

watch:{
  /*监听全选事件*/
  checkArr:{
    handler(value){
      var _this = this;
      var count=0;
      for(var i=0;i<value.length;i++){
        if(value[i].isCheck==true){
          count++;
        }
      }
      //如果子集全部选中,全选按钮设置选中状态
      if(count==value.length){
        _this.allCheck=true;
      }else{
        _this.allCheck=false;
      }
    },
    deep:true
  },
}

总结

以上所述是小编给大家介绍的vue使用监听实现全选反选功能,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对三水点靠木网站的支持!

Javascript 相关文章推荐
jQuery EasyUI API 中文文档 - Spinner微调器使用
Oct 21 Javascript
javascript开发随笔二 动态加载js和文件
Nov 25 Javascript
jquery子元素过滤选择器使用示例
Jun 24 Javascript
jquery弹出框的用法示例(一)
Aug 26 Javascript
浅析JavaScript中的同名标识符优先级
Dec 06 Javascript
jQuery轻松实现表格的隔行变色和点击行变色的实例代码
May 09 Javascript
对VUE中的对象添加属性
Sep 18 Javascript
angularJs中$scope数据序列化的实例
Sep 30 Javascript
Vue中的组件及路由使用实例代码详解
May 22 Javascript
js实现图片区域可点击大小随意改变(适用移动端)代码实例
Sep 11 Javascript
解决vue组件中click事件失效的问题
Nov 09 Javascript
vue 动态生成拓扑图的示例
Jan 03 Vue.js
vue 实现数字滚动增加效果的实例代码
Jul 06 #Javascript
详解在Vue中使用TypeScript的一些思考(实践)
Jul 06 #Javascript
javascript显示动态时间的方法汇总
Jul 06 #Javascript
Django+Vue跨域环境配置详解
Jul 06 #Javascript
微信小程序画布圆形进度条显示效果
Nov 17 #Javascript
微信小程序实时聊天WebSocket
Jul 05 #Javascript
vue v-model实现自定义样式多选与单选功能
Jul 05 #Javascript
You might like
如何使用PHP获取指定日期所在月的开始日期与结束日期
2013/08/01 PHP
php递归使用示例(php递归函数)
2014/02/14 PHP
基于jquery的表头固定的若干方法
2011/01/27 Javascript
script不刷新页面的联动前后代码
2013/09/18 Javascript
jquery实现显示已选用户
2014/07/21 Javascript
Javascript中call和apply函数的比较和使用实例
2015/02/03 Javascript
JavaScript数组去重由慢到快由繁到简(优化篇)
2016/08/26 Javascript
javascript动画之模拟拖拽效果篇
2016/09/26 Javascript
input 标签实现输入框带提示文字效果(两种方法)
2017/10/09 Javascript
Angular4.0中引入laydate.js日期插件的方法教程
2017/12/25 Javascript
bootstrap fileinput插件实现预览上传照片功能
2018/01/23 Javascript
JS实现点击拉拽轮播图pc端移动端适配
2018/09/05 Javascript
Jquery获取radio选中值实例总结
2019/01/17 jQuery
vue2.0 如何在hash模式下实现微信分享
2019/01/22 Javascript
JavaScript数组及常见操作方法小结
2019/11/13 Javascript
JS中锚点链接点击平滑滚动并自由调整到顶部位置
2021/02/06 Javascript
Python分支结构(switch)操作简介
2018/01/17 Python
Python 获得命令行参数的方法(推荐)
2018/01/24 Python
python如何去除字符串中不想要的字符
2020/07/05 Python
python 实现判断ip连通性的方法总结
2018/04/22 Python
tensorflow 中对数组元素的操作方法
2018/07/27 Python
python获取点击的坐标画图形的方法
2019/07/09 Python
python Paramiko使用示例
2020/09/21 Python
matplotlib绘制正余弦曲线图的实现
2021/02/22 Python
英国美发和美容产品商城:HQhair
2019/02/08 全球购物
在线课程:Skillshare
2019/04/02 全球购物
精致的手工皮鞋:Shoe Embassy
2019/11/08 全球购物
SNIDEL官网:日本VIVI杂志人气少女第一品牌
2020/03/12 全球购物
高中的自我鉴定
2013/12/16 职场文书
2014年党课学习材料
2014/05/11 职场文书
教师党员自我评价范文
2015/03/04 职场文书
血轮眼轮回眼特效 html+css
2021/03/31 HTML / CSS
vue+springboot实现登录验证码
2021/05/27 Vue.js
如何使用PyCharm及常用配置详解
2021/06/03 Python
Python利用Turtle绘制哆啦A梦和小猪佩奇
2022/04/04 Python
python模拟浏览器 使用selenium进入好友QQ空间并留言
2022/04/12 Python