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 CHECKBOX全选,取消全选,反选方法三
Aug 30 Javascript
CSS+Table图文混排中实现文本自适应图片宽度(超简单+跨所有浏览器)
Feb 14 Javascript
js arguments.callee的应用代码
May 07 Javascript
预加载css或javascript的js代码
Apr 23 Javascript
Bootstrap每天必学之媒体对象
Nov 30 Javascript
详解JavaScript基于面向对象之继承实例
Dec 16 Javascript
JS实现Select的option上下移动的方法
Mar 01 Javascript
Javascript 基础---Ajax入门必看
Jul 06 Javascript
Vue中的v-cloak使用解读
Mar 27 Javascript
Vue.js实现输入框绑定的实例代码
Aug 24 Javascript
关于vue v-for 循环问题(一行显示四个,每一行的最右边那个计算属性)
Sep 04 Javascript
原生JS实现天气预报
Jun 16 Javascript
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将HTML转换成文本的实现代码
2015/01/21 PHP
PHP中抽象类和抽象方法概念与用法分析
2016/05/24 PHP
jquery实现图片翻页效果
2013/12/23 Javascript
使用原生JS实现弹出层特效
2014/12/22 Javascript
javascript实现瀑布流自适应遇到的问题及解决方案
2015/01/28 Javascript
JavaScript setTimeout使用闭包功能实现定时打印数值
2015/12/18 Javascript
jQuery添加删除DOM元素方法详解
2016/01/18 Javascript
如何使用PHP+jQuery+MySQL实现异步加载ECharts地图数据(附源码下载)
2016/02/23 Javascript
javascript 继承学习心得总结
2016/03/17 Javascript
一次$.getJSON不执行的简单记录
2016/07/19 Javascript
js实现做通讯录的索引滑动显示效果和滑动显示锚点效果
2017/02/18 Javascript
js从输入框读取内容,比较两个数字的大小方法
2017/03/13 Javascript
Vue.js基础学习之class与样式绑定
2017/03/20 Javascript
javascript代码优化的8点总结
2018/01/29 Javascript
JavaScript自动生成 年月范围 选择功能完整示例【基于jQuery插件】
2019/09/03 jQuery
关于vue的列表图片选中打钩操作
2020/09/09 Javascript
Python中__name__的使用实例
2015/04/14 Python
flask框架中勾子函数的使用详解
2018/08/01 Python
用Python shell简化开发
2018/08/08 Python
Python文件监听工具pyinotify与watchdog实例
2018/10/15 Python
django框架实现模板中获取request 的各种信息示例
2019/07/01 Python
Python 开发工具PyCharm安装教程图文详解(新手必看)
2020/02/28 Python
python支持多继承吗
2020/06/19 Python
Python 2.6.6升级到Python2.7.15的详细步骤
2020/12/14 Python
HTML5 window/iframe跨域传递消息 API介绍
2013/08/26 HTML / CSS
html5的canvas方法使用指南
2014/12/15 HTML / CSS
C语言笔试题回忆
2015/04/02 面试题
网络专业学生个人的自我评价
2013/12/16 职场文书
书香校园建设方案
2014/05/02 职场文书
服务承诺书怎么写
2014/05/24 职场文书
行为规范主题班会
2015/08/13 职场文书
导游词之晋城蟒河
2019/12/12 职场文书
Github 使用python对copilot做些简单使用测试
2022/04/14 Python
python中的random模块和相关函数详解
2022/04/22 Python
Spring boot实现上传文件到本地服务器
2022/08/14 Java/Android
前端框架ECharts dataset对数据可视化的高级管理
2022/12/24 Javascript