Angularjs單選改為多選的開發(fā)過程及問題解析
很簡單的需求:之前下拉框是單選,現(xiàn)在想改為多選。
開發(fā)過程:
問題一:自己首先想到的是網(wǎng)上找個example,發(fā)現(xiàn)貌似AngularJS
有相應(yīng)的js包來實現(xiàn),其中最多的就是isteven-multi-select
和angularjs-dropdown-multiselect
等。
我下載了,但是套到自己項目里面,是在是難看的很。而且貌似這些js包耦合性很高,不是我想要的那種,所以還是打算用簡單的md-select、md-option、md-checkbox
來實現(xiàn)我想要的效果,又不想寫的太人工,所以就查angularjs的一些控件demo,最后果然發(fā)現(xiàn)了我想要的。
https://material.angularjs.org/1.1.3/demo/select
于是我就開始往項目里套,但是怎么套,都出不了demo上的樣式,多選是能多選了,但是沒有像checkbox那種正方形選擇框,各種百度各種google,就是不知道什么原因。本來打算都要放棄了,但是這么好的demo,這么省事的js,不忍心放棄啊,再說放棄也找不到其他比較合適的而又不顯突兀的樣式。于是耐下心來一遍遍的去看setting,所有的都沒問題,除了版本不一致。難道?我的第六感告訴我,或許真的是版本原因。之前用的版本是"angular-material": "1.0.0-rc2",改用最新版本"angular-material": "1.1.3",于是,效果出來了,真的是版本原因,容我默默的在衛(wèi)生間哭一會兒。
問題二:樣式的問題解決了,離成功不遠了。想做個多選效果,因為選項實在是很多,沒有多選實在是體驗不好。于是就用其中的一個option來做全選,但是不知道option都有什么事件,找不到相應(yīng)的屬性說明文檔,只有一個checked屬性,但是在js里面又不知道如何判斷checked還是沒有checked,最后還是放棄了,最上面做了個按鈕,搞定。
問題三:還有個問題,就是更新"angular-material": "1.1.3"版本之后,似乎md-input-Container label長度過長的話,就顯示3Dot(...)了,而之前是可以換行顯示的,感覺這個體驗完全不如之前版本的體驗。網(wǎng)上google了好久也沒google出來這樣修正的好處,于是果斷自定義css,改回原來的樣式。
涉及到的部分代碼:
html:
<md-input-container flex="35" class="md-input-has-value"> <label>產(chǎn)品類型</label> <md-select ng-model="params.productType" md-on-close="clearSearchTerm()" ng-change="change(params.productType)" data-md-container-class="selectHeader" multiple> <div> <button ng-click="pTCheckNone()" class="md-button md-ink-ripple"><i class="zmdi zmdi-undo ng-scope"></i>重置</button> </div> <md-select-header class="select-header"> <input ng-model="searchTerm" type="search" placeholder="Search for a product.." class="header-searchbox md-text" > </md-select-header> <md-optgroup label="productTypes"> <md-option value="{{item.key}}" ng-repeat="item in productTypes | filter:searchTerm">{{item.value}}</md-option> </md-optgroup> </md-select> </md-input-container>
js:
$scope.productTypes = [ {"key":"SecureSiteProEV1", "value":"product1"}, {"key":"SecureSiteProEV2", "value":"product2"}, {"key":"SecureSiteProEV3", "value":"product3"}, {"key":"SecureSiteProEV4", "value":"product4"}, {"key":"SecureSiteProEV5", "value":"product5"}];
css
md-input-container label:not(.md-no-float):not(.md-container-ignore), md-input-container .md-placeholder { white-space: normal; }
- 利用VS Code開發(fā)你的第一個AngularJS 2應(yīng)用程序
- AngularJS框架中的雙向數(shù)據(jù)綁定機制詳解【減少需要重復(fù)的開發(fā)代碼量】
- 基于NodeJS+MongoDB+AngularJS+Bootstrap開發(fā)書店案例分析
- AngularJS開發(fā)教程之控制器之間的通信方法分析
- Ubuntu系統(tǒng)下Angularjs開發(fā)環(huán)境安裝
- 總結(jié)AngularJS開發(fā)者最常犯的十個錯誤
- 利用Angularjs和Bootstrap前端開發(fā)案例實戰(zhàn)
- AngularJS應(yīng)用開發(fā)思維之依賴注入3
- angularJS開發(fā)注意事項
相關(guān)文章
AngularJS對動態(tài)增加的DOM實現(xiàn)ng-keyup事件示例
這篇文章主要介紹了AngularJS對動態(tài)增加的DOM實現(xiàn)ng-keyup事件示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-03-03高效利用Angular中內(nèi)置服務(wù)$http、$location等
這篇文章主要介紹了如何高效利用Angular中內(nèi)置服務(wù),大家知道的Angular內(nèi)置服務(wù)有哪些,感興趣的小伙伴們可以參考一下2016-03-03詳解angularJs中關(guān)于ng-class的三種使用方式說明
本篇文章主要介紹了angularJs中關(guān)于ng-class的三種使用方式說明,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-06-06詳解angular2采用自定義指令(Directive)方式加載jquery插件
本篇文章主要介紹了詳解angular2采用自定義指令(Directive)方式加載jquery插件 ,具有一定的參考價值,感興趣的小伙伴們可以參考一下。2017-02-02淺析如何利用angular結(jié)合translate為項目實現(xiàn)國際化
利用angular進行國際化轉(zhuǎn)換時利用【ng-bind-html】來進行語言的翻譯是接近幾乎比較完美的方案,不會像利用【{{}}】模式,當頁面加載緩慢時導(dǎo)致頁面太丑。本文對其實現(xiàn)方法進行介紹,有需要的朋友可以看下2016-12-12