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 相关文章推荐
基于JQuery的抓取博客园首页RSS的代码
Dec 01 Javascript
ExtJS4中使用mixins实现多继承示例
Dec 03 Javascript
JavaScript对IE操作的经典代码(推荐)
Mar 10 Javascript
js仿黑客帝国字母掉落效果代码分享
Nov 08 Javascript
AngularJS基础 ng-submit 指令简单示例
Aug 03 Javascript
javascript 动态样式添加的简单实现
Oct 11 Javascript
ECMAScript6 新特性范例大全
Mar 24 Javascript
Vue.js仿微信聊天窗口展示组件功能
Aug 11 Javascript
详解a++和++a的区别
Aug 30 Javascript
详解js加减乘除精确计算
Mar 19 Javascript
使用 Vue-TCB 快速在 Vue 应用中接入云开发的方法
Feb 10 Javascript
vue前端工程的搭建
Mar 31 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中date()日期函数有关参数整理
2011/07/19 PHP
浅谈PHP匿名函数和闭包
2019/03/08 PHP
jQuery EasyUI API 中文文档 - ComboTree组合树
2011/10/11 Javascript
jquery animate实现鼠标放上去显示离开隐藏效果
2013/07/21 Javascript
js 3种归并操作的实例代码
2013/10/30 Javascript
javascript:json数据的页面绑定示例代码
2014/01/26 Javascript
JS控制输入框内字符串长度
2014/05/21 Javascript
在Ubuntu上安装最新版本的Node.js
2014/07/14 Javascript
基于jQuery实现自动轮播旋转木马特效
2015/11/02 Javascript
BootStrap的alert提示框的关闭后再显示怎么解决
2016/05/17 Javascript
移动端H5开发 Turn.js实现很棒的翻书效果
2016/06/20 Javascript
使用vue实现点击按钮滑出面板的实现代码
2017/01/10 Javascript
es6学习笔记之Async函数基本教程
2017/05/11 Javascript
CheckBox多选取值及判断CheckBox选中是否为空的实例
2017/10/31 Javascript
浅谈Redux中间件的实践
2018/07/27 Javascript
vue之a-table中实现清空选中的数据
2019/11/07 Javascript
jQuery实现可以计算进制转换的计算器
2020/10/19 jQuery
跟老齐学Python之编写类之四再论继承
2014/10/11 Python
对python 通过ssh访问数据库的实例详解
2019/02/19 Python
python 实现的发送邮件模板【普通邮件、带附件、带图片邮件】
2019/07/06 Python
Python缓存技术实现过程详解
2019/09/25 Python
Numpy中np.max的用法及np.maximum区别
2020/11/27 Python
浅析移动设备HTML5页面布局
2015/12/01 HTML / CSS
华三通信H3C面试题
2015/05/15 面试题
基于Python 函数和方法的区别说明
2021/03/24 Python
仓管员岗位职责范文
2013/11/08 职场文书
产品销售员岗位职责
2013/12/18 职场文书
你懂得怎么写自荐信吗?
2013/12/27 职场文书
学校十一活动方案
2014/02/01 职场文书
故宫英文导游词
2015/01/31 职场文书
2015暑期社会实践通讯稿
2015/07/18 职场文书
2016年第十四个公民道德宣传日活动总
2016/04/01 职场文书
优秀员工演讲稿
2019/06/21 职场文书
MySQL命令行操作时的编码问题详解
2021/04/14 MySQL
python 远程执行命令的详细代码
2022/02/15 Python
Python如何将list中的string转换为int
2022/07/15 Ruby