javascript使用avalon绑定实现checkbox全选


Posted in Javascript onMay 06, 2015

duplex双工绑定是avalon绑定里面最有趣的一个,因为它在内部帮开发者做了很多事,让开发者写的代码减少,代码更优雅。下面随便演示一个常见的checkbox全选。

要求:(老掉牙了,还是说一下)

1.勾选了全选框后,下面的子选框全被勾选;没勾选全选框,则子选框全部不勾选

2.子选框如果有一个未勾选,则取消全选框勾选;

3.子选框全部勾选,则勾选全选框

<!DOCTYPE html>
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<title></title>
<style type="text/css">
  *{
    margin: 0;
    padding: 0;
  }
  #wrap{
    margin-left: 100px;
  }
  #wrap li{
    display: inline-block;
    *display: inline;
    zoom:1;
    vertical-align: middle;
  }
</style>
<script type="text/javascript" src='seed.js'></script>
</head>
<body>
  <div id='wrap' ms-controller='duplex'>
    <p><input type='checkbox' data-duplex-changed="select_all_cb" ms-duplex-checked='select_all'>全选</p>
    <ul>
      <li ms-repeat='list'>
        <input type='checkbox' ms-duplex-number="selected" ms-attr-value='el.id'>{{el.text}}
      </li>
    </ul>
    <p>选中项的id:{{selected}}</p>
  </div>
  <script type="text/javascript">
  require('avalon',function(avalon){
    var duplex=avalon.define('duplex',function(vm){
      vm.selected=[];//保存勾选的选项的id,方便传给后台
      vm.list=[{id:1,text:'aaa'},{id:2,text:'bbb'},{id:3,text:'ccc'},{id:4,text:'ddd'},{id:5,text:'eee'},{id:6,text:'fff'}];
      vm.select_all_cb=function(){//全选框change事件回调
        var list=duplex.list,selected=duplex.selected;
        if(this.checked){
          avalon.each(list,function(i,v){//循环保存着已经勾选选框的数据
            selected.ensure(v['id']);//如果里面没有当前选框的数据,就保存
          });
        }else
          selected.clear();//清空
      };
      vm.select_all=0;
    });
    duplex.selected.$watch('length',function(after){//监听保存数据数组的变化
      var len=duplex.list.length;      
      if(after==len)//子选框全部被勾选
        duplex.select_all=1;
      else//子选框有一个没有被勾选
        duplex.select_all=0;
    });
    avalon.scan();
  });
  </script>
</body>
</html>

效果

javascript使用avalon绑定实现checkbox全选

需要说明几点:

1.data-duplex-changed负责监听checkbox的变化,进而触发回调。

2.ms-duplex-number="selected"这个就是神器,selected数组是和子选项框同步的,互相影响。也就是说,selected数组的元素个数增加或减少,会更新相应子选项框的视图,反之亦然。

3.ms-duplex-*需要与checkbox value属性值的类型相同,否则无法同步视图。像这里,checkbox value值是数字,则用ms-duplex-number。

4.checkbox value属性值的类型有时不要想当然的去判定。本?啪陀龅焦??髅鞔雍筇ù??吹氖?d数字,却无法同步视图,最后改成ms-duplex-string才解决问题。所以'7'还是7,要判断清楚。

从这个小例子可以看到用avalon这类mvvc是多么的提升编码体验,如果不用,想想要写多少个for循环+if判断!

以上所述就是本文的全部内容了,希望大家能够喜欢。

Javascript 相关文章推荐
滚动条变色 隐藏滚动条与双击网页自动滚屏显示代码
Dec 28 Javascript
js进行表单验证实例分析
Feb 10 Javascript
使用js获取地址栏参数的方法推荐(超级简单)
Jun 14 Javascript
AngularJS模仿Form表单提交的实现代码
Dec 08 Javascript
javascript中apply/call和bind的使用
Feb 15 Javascript
JavaScript异步上传图片文件的实例代码
Jul 04 Javascript
详解vue-cli3使用
Aug 14 Javascript
详解vue-cli 脚手架 安装
Apr 16 Javascript
jQuery实现文本显示一段时间后隐藏的方法分析
Jun 20 jQuery
JS中FileReader类实现文件上传及时预览功能
Mar 27 Javascript
解决新建一个vue项目过程中遇到的问题
Oct 22 Javascript
vue如何实现关闭对话框后刷新列表
Apr 08 Vue.js
js实现滑动触屏事件监听的方法
May 05 #Javascript
JS根据生日算年龄的方法
May 05 #Javascript
js改变Iframe中Src的方法
May 05 #Javascript
js网页滚动条滚动事件实例分析
May 05 #Javascript
jquery判断单选按钮radio是否选中的方法
May 05 #Javascript
JQuery中Bind()事件用法分析
May 05 #Javascript
JS判断字符串包含的方法
May 05 #Javascript
You might like
PHP网站安装程序制作的原理、步骤、注意事项和示例代码
2010/08/01 PHP
使用php shell命令合并图片的代码
2011/06/23 PHP
php数组函数array_key_exists()小结
2015/12/10 PHP
PHP通过get方法获得form表单数据方法总结
2018/09/12 PHP
新页面打开实际尺寸的图片
2006/08/25 Javascript
javascript编程起步(第七课)
2007/02/27 Javascript
基于jquery实现的一个选择中国大学的弹框 (数据、步骤、代码)
2012/07/26 Javascript
一个级联菜单代码学习及removeClass与addClass的应用
2013/01/24 Javascript
javascript实现根据iphone屏幕方向调用不同样式表的方法
2015/07/13 Javascript
js如何实现点击标签文字,文字在文本框出现
2015/08/05 Javascript
WordPress中利用AJAX技术进行评论提交的实现示例
2016/01/12 Javascript
Angular实现form自动布局
2016/01/28 Javascript
理解javascript中的with关键字
2016/02/15 Javascript
js仿支付宝填写支付密码效果实现多方框输入密码
2016/03/09 Javascript
JS读取XML文件数据并以table形式显示数据的方法(兼容IE与火狐)
2016/06/02 Javascript
详解vue-Resource(与后端数据交互)
2017/01/16 Javascript
vue-resouce设置请求头的三种方法
2017/09/12 Javascript
微信小程序实现滑动翻页效果(完整代码)
2019/12/06 Javascript
vue-router 按需加载 component: () =&gt; import() 报错的解决
2020/09/22 Javascript
[06:20]2015国际邀请赛第三日top10
2015/08/08 DOTA
Python遍历目录的4种方法实例介绍
2015/04/13 Python
Python的GUI框架PySide的安装配置教程
2016/02/16 Python
浅谈python字符串方法的简单使用
2016/07/18 Python
python3.5+tesseract+adb实现西瓜视频或头脑王者辅助答题
2018/01/17 Python
Python实现的绘制三维双螺旋线图形功能示例
2018/06/23 Python
Window 64位下python3.6.2环境搭建图文教程
2018/09/19 Python
Python requests模块安装及使用教程图解
2020/06/30 Python
CSS3 box-sizing属性详解
2016/11/15 HTML / CSS
护士自我鉴定
2013/10/23 职场文书
个人简历自荐信
2013/12/05 职场文书
大学生学期个人总结
2015/02/12 职场文书
西游记读书笔记
2015/06/25 职场文书
2016年教师新年寄语
2015/08/18 职场文书
班主任培训研修日志
2015/11/13 职场文书
《月球之谜》教学反思
2016/02/20 职场文书
nginx.conf配置文件结构小结
2022/04/08 Servers