javascript使用avalon綁定實(shí)現(xiàn)checkbox全選
duplex雙工綁定是avalon綁定里面最有趣的一個(gè),因?yàn)樗趦?nèi)部幫開(kāi)發(fā)者做了很多事,讓開(kāi)發(fā)者寫(xiě)的代碼減少,代碼更優(yōu)雅。下面隨便演示一個(gè)常見(jiàn)的checkbox全選。
要求:(老掉牙了,還是說(shuō)一下)
1.勾選了全選框后,下面的子選框全被勾選;沒(méi)勾選全選框,則子選框全部不勾選
2.子選框如果有一個(gè)未勾選,則取消全選框勾選;
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>選中項(xiàng)的id:{{selected}}</p> </div> <script type="text/javascript"> require('avalon',function(avalon){ var duplex=avalon.define('duplex',function(vm){ vm.selected=[];//保存勾選的選項(xiàng)的id,方便傳給后臺(tái) 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事件回調(diào) var list=duplex.list,selected=duplex.selected; if(this.checked){ avalon.each(list,function(i,v){//循環(huán)保存著已經(jīng)勾選選框的數(shù)據(jù) selected.ensure(v['id']);//如果里面沒(méi)有當(dāng)前選框的數(shù)據(jù),就保存 }); }else selected.clear();//清空 }; vm.select_all=0; }); duplex.selected.$watch('length',function(after){//監(jiān)聽(tīng)保存數(shù)據(jù)數(shù)組的變化 var len=duplex.list.length; if(after==len)//子選框全部被勾選 duplex.select_all=1; else//子選框有一個(gè)沒(méi)有被勾選 duplex.select_all=0; }); avalon.scan(); }); </script> </body> </html>
效果
需要說(shuō)明幾點(diǎn):
1.data-duplex-changed負(fù)責(zé)監(jiān)聽(tīng)checkbox的變化,進(jìn)而觸發(fā)回調(diào)。
2.ms-duplex-number="selected"這個(gè)就是神器,selected數(shù)組是和子選項(xiàng)框同步的,互相影響。也就是說(shuō),selected數(shù)組的元素個(gè)數(shù)增加或減少,會(huì)更新相應(yīng)子選項(xiàng)框的視圖,反之亦然。
3.ms-duplex-*需要與checkbox value屬性值的類型相同,否則無(wú)法同步視圖。像這里,checkbox value值是數(shù)字,則用ms-duplex-number。
4.checkbox value屬性值的類型有時(shí)不要想當(dāng)然的去判定。本屌就遇到過(guò),明明從后臺(tái)傳過(guò)來(lái)的是id數(shù)字,卻無(wú)法同步視圖,最后改成ms-duplex-string才解決問(wèn)題。所以'7'還是7,要判斷清楚。
從這個(gè)小例子可以看到用avalon這類mvvc是多么的提升編碼體驗(yàn),如果不用,想想要寫(xiě)多少個(gè)for循環(huán)+if判斷!
以上所述就是本文的全部?jī)?nèi)容了,希望大家能夠喜歡。
相關(guān)文章
php結(jié)合js實(shí)現(xiàn)多條件組合查詢
這篇文章主要為大家詳細(xì)介紹了php結(jié)合js實(shí)現(xiàn)多條件組合查詢,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2019-05-05IE6與IE7中,innerHTML獲取param的區(qū)別
最近,在用一些web編輯器,發(fā)現(xiàn)插入一段mp3后,查看源代碼,object標(biāo)簽中的param都被刪除。下面我演示給大家看看。2009-03-03js控制元素顯示在屏幕固定位置及監(jiān)聽(tīng)屏幕高度變化的方法
這篇文章主要介紹了js控制元素顯示在屏幕固定位置及監(jiān)聽(tīng)屏幕高度變化的方法,涉及javascript針對(duì)頁(yè)面元素及樣式屬性的相關(guān)操作技巧,需要的朋友可以參考下2015-08-08JavaScript Konami Code 實(shí)現(xiàn)代碼
JavaScript Konami Code 實(shí)現(xiàn)代碼2009-07-07js隱藏與顯示回到頂部按鈕及window.onscroll事件應(yīng)用
現(xiàn)在大多數(shù)網(wǎng)站都會(huì)添加這種功能:當(dāng)滾動(dòng)條滾動(dòng)到頁(yè)面的下方時(shí),頁(yè)面的右下角會(huì)顯示出來(lái)一個(gè)“回到頂部”的按鈕或連接;那么,如何控制“回到頂部”按鈕的顯示或隱藏呢;本文介紹詳細(xì)實(shí)現(xiàn)方法,感興趣的你可不要走開(kāi)哦2013-01-01javascript截取字符串(通過(guò)substring實(shí)現(xiàn)并支持中英文混合)
用js方法substring()、方法substr()實(shí)現(xiàn)如標(biāo)題所示的截取字符串并支持中英文混合,具體代碼如下,感興趣的各位可以參考下哈2013-06-06JavaScript解決單線程缺陷webWorker問(wèn)題
Web Worker 為 Web 內(nèi)容在后臺(tái)線程中運(yùn)行腳本提供了一種簡(jiǎn)單的方法,本文給大家介紹JavaScript解決單線程缺陷——webWorker,需要的朋友可以參考下2023-06-06