avalon js實現checkbox全選

轉載請註明: TheViper http://www.cnblogs.com/TheViper javascript

duplex雙工綁定是avalon綁定裏面最有趣的一個,由於它在內部幫開發者作了不少事,讓開發者寫的代碼減小,代碼更優雅。下面隨便演示一個常見的checkbox全選。css

要求:(老掉牙了,仍是說一下)html

1.勾選了全選框後,下面的子選框全被勾選;沒勾選全選框,則子選框所有不勾選java

2.子選框若是有一個未勾選,則取消全選框勾選;數組

3.子選框所有勾選,則勾選全選框ui

<!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>

效果this

須要說明幾點:編碼

1.data-duplex-changed負責監聽checkbox的變化,進而觸發回調。spa

2.ms-duplex-number="selected"這個就是神器,selected數組是和子選項框同步的,互相影響。也就是說,selected數組的元素個數增長或減小,會更新相應子選項框的視圖,反之亦然。code

3.ms-duplex-*須要與checkbox value屬性值的類型相同,不然沒法同步視圖。像這裏,checkbox value值是數字,則用ms-duplex-number。

4.checkbox value屬性值的類型有時不要想固然的去斷定。本屌就遇到過,明明從後臺傳過來的是id數字,卻沒法同步視圖,最後改爲ms-duplex-string才解決問題。因此'7'仍是7,要判斷清楚。

從這個小例子能夠看到用avalon這類mvvc是多麼的提高編碼體驗,若是不用,想一想要寫多少個for循環+if判斷!

相關文章
相關標籤/搜索