AngularJS過濾器filter用法分析
本文實例講述了AngularJS過濾器filter用法。分享給大家供大家參考,具體如下:
在開發(fā)中,經(jīng)常會遇到這樣的場景
如用戶的性別分為“男”和“女”,在數(shù)據(jù)庫中保存的值為1和0,用戶在查看自己的性別時后端返回的值自然是1或0,前端要轉換為“男”或“女”再顯示出來;
如我要換個羽毛球拍,某貓上羽毛球拍的品牌多達數(shù)十種,我想單獨查看YONEX這個品牌的羽毛球拍;
買完羽毛球拍我還想買一桶羽毛球,點擊按銷量排序展示商品;
以上三種場景分別對數(shù)據(jù)進行了轉換/篩選/排序,總而言之就是對數(shù)據(jù)的格式化,AngularJS的filter就是用來做這個事的。
內(nèi)置過濾器
AngularJS內(nèi)置了很多過濾器,在HTML模板的綁定符號{{}}內(nèi)通過|來調(diào)用過濾器
如字母轉換成大寫:
$scope.name='wangmeijian' {{name | uppercase}} // 輸出 WANGMEIJIAN
數(shù)字轉成千分位寫法:
$scope.num = 12345678 {{num | number}} // 輸出 12,345,678
日期格式化:
$scope.date=new Date() {{date | date:'yy-MM-dd'}} // 輸出 2015-11-19
數(shù)字格式化成貨幣:
$scope.num=987654321 {{num | currency:'¥'}} // 輸出 ¥987,654,321.00
demo示例:http://runjs.cn/code/ztgq7fwg
稍微復雜一點的過濾器——‘filter',可以返回給定數(shù)組的子集,它接收一個參數(shù),這個參數(shù)可以是字符串、對象、函數(shù)
字符串:返回所有包含這個字符串的元素,想要返回不包含這個字符串的元素則在前面加!
demo:
{{['wang','mei','jian'] | filter:'a'}} // 返回包含字母a的元素 ['wang','jian']
對象:Angular會將待過濾對象的屬性與這個對象中的同名屬性進行比較,如果屬性值是字符串會判斷是否包含該字符串(注意這里是包含,并不需要完全相等)
demo:
{{ [ { name: 'wangmeijian', sex: 'boy' }, { name: 'bokeyuan', sex: 'sex' } ] | filter:{ sex: 'bo' } }} // 輸出 [{"name":"wangmeijian","sex":"boy"}]
函數(shù):對每個元素都執(zhí)行該函數(shù),返回非假值的元素會出現(xiàn)在新的數(shù)組中并返回
demo:
$scope.getNumber = function(n){ return !isNaN(n); } {{ ['demo',2,3] | filter:getNumber}} // 輸出 [2,3]
自定義過濾器
當內(nèi)置函數(shù)不能滿足你的業(yè)務需求時,就需要自定義一個過濾器,自定義過濾器返回一個函數(shù),函數(shù)的參數(shù)就是HTML模板中|左側的數(shù)據(jù),它會自動傳入過濾器中
比如需求是將一句話中的每個單詞首字母變成大寫
<html ng-app='app'> <head> <title>AngularJS過濾器filter入門</title> <script type="text/javascript" src="http://cdn.bootcss.com/angular.js/1.5.0-beta.1/angular.js"></script> </head> <body ng-controller='myController'> <p>{{ str | capitalize}}</p> <!-- 輸出 Hello, Welcome To Bokeyuan! --> <script type="text/javascript"> var app = angular.module('app',[]) .controller('myController',['$scope', function($scope){ $scope.str = 'hello, welcome to bokeyuan!' }]) .filter('capitalize', function(){ return function(str){ var arr = str.split(/\s+/); for (var i = 0; i < arr.length; i++) { arr[i] = arr[i].substr(0,1).toUpperCase() + arr[i].slice(1); }; return arr.join(" ") } }) </script> </body> </html>
需要注意的是,內(nèi)置過濾器‘filter'的參數(shù)是函數(shù)時,會對數(shù)組的每個元素執(zhí)行該函數(shù),自定義過濾器是對數(shù)組對象執(zhí)行它return的函數(shù)。
更多關于AngularJS相關內(nèi)容感興趣的讀者可查看本站專題:《AngularJS入門與進階教程》及《AngularJS MVC架構總結》
希望本文所述對大家AngularJS程序設計有所幫助。
相關文章
Angular中ng-template和ng-container的應用小結
Angular的日常工作中經(jīng)常會使用到ng-template和ng-container,本文對他們做一個總結,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧2022-06-06AngularJS實現(xiàn)單獨作用域內(nèi)的數(shù)據(jù)操作
這篇文章給大家介紹了利用AngularJs如何實現(xiàn)ng-repeat內(nèi)各個小的子作用域單獨數(shù)據(jù)綁定。有需要的小伙伴們可以參考借鑒,下面來一起看看吧。2016-09-09Angular使用動態(tài)加載組件方法實現(xiàn)Dialog的示例
這篇文章主要介紹了Angular使用動態(tài)加載組件方法實現(xiàn)Dialog的示例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-05-05AngularJS創(chuàng)建一個上傳照片的指令實例代碼
這篇文章主要介紹了AngularJS創(chuàng)建一個上傳照片的指令實例代碼,需要的朋友可以參考下2018-02-02AngularJS標簽頁tab選項卡切換功能經(jīng)典實例詳解
這篇文章主要介紹了AngularJS實現(xiàn)標簽頁tab選項卡功能,結合實例形式總結分析了各種常用的tab選項卡切換操作實現(xiàn)技巧與相關操作注意事項,需要的朋友可以參考下2018-05-05Angular 2父子組件數(shù)據(jù)傳遞之局部變量獲取子組件其他成員
這篇文章主要給大家介紹了關于Angular 2父子組件之間數(shù)據(jù)傳遞之局部變量獲取子組件其他成員的相關資料,文中通過示例代碼介紹的非常詳細,對大家具有一定的參考學習價值,需要的朋友們下面來一起看看吧。2017-07-07AngularJS入門心得之directive和controller通信過程
Angular JS (Angular.JS) 是一組用來開發(fā)Web頁面的框架、模板以及數(shù)據(jù)綁定和豐富UI組件,接下來通過本文給大家介紹AngularJS入門心得之directive和controller通信過程,對angularjs相關知識感興趣的朋友一起學習吧2016-01-01