亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 網站 > WEB開發 > 正文

angular學習(十)—— 過濾器

2024-04-27 15:11:06
字體:
來源:轉載
供稿:網友

過濾器

過濾器將表達式的運算結果格式化后呈現給用戶,可以用于視圖模版,控制器或者服務。angularjs有一些內置的過濾器,如果想自己自定義也很容易。

在視圖模版中使用過濾器

過濾器可以用于視圖模版中的表達式,語法如下:

{{ exPRession | filter }}

例如,{{ 12 | currency }}將數字12用currency過濾器格式化為貨幣輸出,最后的結果為$12.00。

angularjs的過濾器也支持過濾鏈,語法如下:

{{ expression | filter1 | filter2 | ... }}

過濾器還能支持參數輸入,語法如下:

{{ expression | filter:argument1:argument2:... }}

例如{{ 1234 | number:2 }}會將數字1234用number過濾器格式化,根據參數保留小數點后2位,結果為 1,234.00

過濾器的運行

視圖模版中的過濾器僅僅在輸入改變時才會執行,這比每一次$digest循環都執行一次要高效的多。

但也有兩種例外的情況:

通常只在輸入是基礎類型的過濾器才會在輸入改變時菜執行。如果過濾器對輸入是object的話,每次$digest過濾器都會執行,因為要監測object是否改變會更耗性能。如果過濾器標記為$stateful,那么也會在每次$digest都執行。

在控制器, 服務和指令中使用過濾器

你也可以在控制器,服務和指令中使用過濾器。

為此,需要將過濾器以<filterName>Filter的語法注入到相應的controller/service/directive中。例如你想注入number過濾器就是用numberFilter,過濾器函數作為控制器的第一個參數注入,過濾器的參數作為控制器函數的第二個參數。

下面的例子所使用的過濾器叫做filter,這個過濾器接受一個數組,并根據過濾條件產生一個子數組。如果在視圖模版中表示的話,可以寫成{{ctrl.array | filter:'a'}},將會對數組以a為關鍵字進行全文搜索。然而,如果在視圖模版中這樣做的話,它會在每次$digest都執行過濾器,這會非常耗費性能。因此下面的例子就將過濾器寫在了控制器中,只有在需要的時候才會調用(例如從后端load數據,或者過濾器的表達式需要改變時)

<!DOCTYPE html><html><head> <meta charset="uft-8"/> <title></title></head><script src="script/angular.min.js"></script><script> angular.module('FilterInControllerModule', []). controller('FilterController', ['filterFilter', function(filterFilter) { this.array = [ {name: 'Tobias'}, {name: 'Jeff'}, {name: 'Brian'}, {name: 'Igor'}, {name: 'James'}, {name: 'Brad'} ]; this.filteredArray = filterFilter(this.array, 'a'); }]);</script><body ng-app="FilterInControllerModule"><div ng-controller="FilterController as ctrl"> <div> All entries: <span ng-repeat="entry in ctrl.array">{{entry.name}} </span> </div> <div> Entries that contain an "a": <span ng-repeat="entry in ctrl.filteredArray">{{entry.name}} </span> </div></div></body></html>

自定義過濾器

自定義一個過濾器也相當容易,僅僅需要在module中注冊一個新的filter工廠函數。工廠函數會返回一個新的過濾器函數,過濾器的輸入作為過濾器函數的第一個參數,其他過濾器的參數作為過濾器函數的附加參數傳入。

過濾器函數是一個純函數,這意味著給出相同的輸入參數總能得到相同的輸出結果,而不受外界狀態的影響(例如,angularjs的services)。根據這一點,angularjs才能做到僅僅當輸入變化時才去執行一次過濾器。帶狀態帶過濾器也存在,但是非常低效。

過濾器的名字必須是有效的angularjs表達式標識符,例如uppercase,orderBy。名字中不能帶有特殊字符,比如.都是不允許的,你可以用駱駝命名法(myappSubsectionFilterx)或者下劃線代替(myapp_subsection_filterx)。

下面的例子是一個反轉字符串的過濾器,并且根據參數可以選擇大小寫:

<!DOCTYPE html><html><head> <meta charset="uft-8"/> <title></title></head><script src="script/angular.min.js"></script><script> angular.module('myReverseFilterApp', []) .filter('reverse', function() { return function(input, uppercase) { input = input || ''; var out = ''; for (var i = 0; i < input.length; i++) { out = input.charAt(i) + out; } // conditional based on optional argument if (uppercase) { out = out.toUpperCase(); } return out; }; }) .controller('MyController', ['$scope', 'reverseFilter', function($scope, reverseFilter) { $scope.greeting = 'hello'; $scope.filteredGreeting = reverseFilter($scope.greeting); }]);</script><body ng-app="myReverseFilterApp"><div ng-controller="MyController"> <input ng-model="greeting" type="text"><br> No filter: {{greeting}}<br> Reverse: {{greeting|reverse}}<br> Reverse + uppercase: {{greeting|reverse:true}}<br> Reverse, filtered in controller: {{filteredGreeting}}<br></div></body></html>

狀態過濾器

強烈建議不要寫有狀態的過濾器,因為angularjs并不會對其做優化,常常會導致性能問題。很多狀態過濾器可以通過暴露模型的狀態并把它作為過濾器的參數傳入,來達到改為不帶狀態的過濾器。

如果你非要寫一個帶狀態帶過濾器,記得把過濾器標記為$stateful,這樣每次$digest循環都好執行一次或多次過濾器。

<!DOCTYPE html><html><head> <meta charset="uft-8"/> <title></title></head><script src="script/angular.min.js"></script><script> angular.module('myStatefulFilterApp', []) .filter('decorate', ['decoration', function(decoration) { function decorateFilter(input) { return decoration.symbol + input + decoration.symbol; } decorateFilter.$stateful = true; return decorateFilter; }]) .controller('MyController', ['$scope', 'decoration', function($scope, decoration) { $scope.greeting = 'hello'; $scope.decoration = decoration; }]) .value('decoration', {symbol: '*'});</script><body ng-app="myStatefulFilterApp"><div ng-controller="MyController"> Input: <input ng-model="greeting" type="text"><br> Decoration: <input ng-model="decoration.symbol" type="text"><br> No filter: {{greeting}}<br> Decorated: {{greeting | decorate}}<br></div></body></html>

上面的例子轉化為無狀態過濾器:

<!DOCTYPE html><html><head> <meta charset="uft-8"/> <title></title></head><script src="script/angular.min.js"></script><script> angular.module('myStatelessFilterApp', []) .filter('decorate', function() { function decorateFilter(input,symbol) { return symbol + input + symbol; } decorateFilter.$stateful = true; return decorateFilter; }) .controller('MyController', ['$scope', function($scope) { $scope.greeting = 'hello'; $scope.symbol="*"; }]) .value('decoration', {symbol: '*'});</script><body ng-app="myStatelessFilterApp"><div ng-controller="MyController"> Input: <input ng-model="greeting" type="text"><br> Decoration: <input ng-model="symbol" type="text"><br> No filter: {{greeting}}<br> Decorated: {{greeting | decorate:symbol}}<br></div></body></html>

如果我的文章對您有幫助,請用支付寶打賞:


上一篇:jquery事件

下一篇:HTML渲染過程詳解

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美激情成人在线视频| 中文字幕自拍vr一区二区三区| 2019中文字幕免费视频| 懂色av影视一区二区三区| 国产精品v日韩精品| 国产精品一区二区三区在线播放| 成人av番号网| 亚洲国产精久久久久久久| 成人精品视频99在线观看免费| 精品福利视频导航| 中文国产亚洲喷潮| 性欧美在线看片a免费观看| 亚洲999一在线观看www| 中文字幕无线精品亚洲乱码一区| 97碰碰碰免费色视频| 蜜月aⅴ免费一区二区三区| 精品亚洲一区二区三区| 久久中文字幕视频| 欧美激情xxxxx| 中文字幕日韩欧美在线视频| 色综合视频网站| 韩国精品美女www爽爽爽视频| 国产+成+人+亚洲欧洲| 色综合导航网站| 欧美亚洲在线播放| 久久九九国产精品怡红院| 久久91亚洲精品中文字幕奶水| 亚洲a∨日韩av高清在线观看| 国产精品旅馆在线| 亚洲精品一区av在线播放| 欧美人与物videos| 97视频网站入口| 国产精品中文字幕在线观看| 91精品久久久久久久久| 欧美精品激情blacked18| 亚洲色在线视频| 亚洲精品国产精品久久清纯直播| 欧美丰满片xxx777| 亚洲影院高清在线| 色综合天天狠天天透天天伊人| 欧美视频一二三| 国产亚洲欧美日韩一区二区| 国产精品午夜国产小视频| 欧美电影免费观看电视剧大全| 国产91亚洲精品| 国产精品∨欧美精品v日韩精品| 亚洲欧美三级在线| 91在线色戒在线| 日韩精品有码在线观看| 亚洲精品动漫100p| 亚洲第一网站男人都懂| 久久人体大胆视频| 欧美日韩一区二区三区在线免费观看| 亚洲3p在线观看| 欧美华人在线视频| 日本精品久久久| 美女福利精品视频| 最近2019中文字幕mv免费看| 国产精品美女久久久免费| 中文字幕精品久久久久| 在线观看91久久久久久| 亚洲人成77777在线观看网| 欧美激情亚洲视频| 日韩一区二区欧美| 欧美理论片在线观看| 日韩欧美在线视频日韩欧美在线视频| 亚洲人成网站777色婷婷| 国产一区二区三区日韩欧美| 亚洲a在线播放| 欧美午夜精品在线| 欧美亚洲激情在线| 最近中文字幕日韩精品| 日韩中文字幕在线播放| 456亚洲影院| 久久影视电视剧免费网站| 欧洲成人性视频| 国产免费一区二区三区在线能观看| 中文字幕亚洲一区| 日本成人免费在线| 激情成人中文字幕| 久久久精品网站| 欧美影院成年免费版| 中文字幕不卡在线视频极品| 亚洲国产私拍精品国模在线观看| 日本不卡免费高清视频| 国产日韩中文字幕在线| 欧美激情免费在线| 亚洲精品ady| 欧美性xxxx极品hd满灌| 91在线观看免费| 亚洲国产精品小视频| 亚洲精品美女在线观看播放| 国产精品av免费在线观看| 色婷婷av一区二区三区久久| 2021国产精品视频| 久久久精品久久久久| 精品久久久久久久久国产字幕| 成人国产精品一区| 午夜精品一区二区三区在线视| 国产成人福利夜色影视| 日韩电影大全免费观看2023年上| 成人网页在线免费观看| 国产精品香蕉在线观看| 青青久久av北条麻妃海外网| 欧美日韩国产中文精品字幕自在自线| 欧美黑人巨大精品一区二区| 国产精品三级网站| 久久久这里只有精品视频| 欧美黑人狂野猛交老妇| 国产丝袜视频一区| 国产精品女人久久久久久| 国产日韩专区在线| 欧美裸身视频免费观看| 国内精品久久久久影院 日本资源| 91在线国产电影| 久久久精品影院| 91社区国产高清| 精品国产一区二区三区久久久狼| 视频在线观看99| 国产精品入口免费视频一| 欧美又大又硬又粗bbbbb| www.亚洲成人| 国产精品私拍pans大尺度在线| 一区二区三区黄色| 中文字幕欧美日韩va免费视频| 亚洲精品免费网站| 欧美黑人又粗大| 精品久久久久久久久久国产| 国产精品久久久久av| 日本久久精品视频| 精品国产拍在线观看| 亚洲女人天堂av| 国产在线不卡精品| 岛国av一区二区在线在线观看| 欧美老女人bb| 国产精品日韩欧美综合| 久久久在线免费观看| 欧美日韩国产精品| 狠狠色香婷婷久久亚洲精品| 日韩av在线网址| 欧美极品欧美精品欧美视频| 久久久免费电影| 亚洲伊人一本大道中文字幕| 亚洲国产高清高潮精品美女| 久久免费视频在线| 日韩精品在线看| 91精品啪aⅴ在线观看国产| 国产女精品视频网站免费| 欧美国产极速在线| 成人黄色av播放免费| 欧美在线性爱视频| 欧美性做爰毛片| 欧美中文在线观看国产| 欧美日韩国产成人在线观看| 日本精品视频在线播放| 亚洲人成毛片在线播放| 欧美性猛交xxxxx免费看| 欧美黑人一级爽快片淫片高清| 色多多国产成人永久免费网站| 国产视频精品xxxx| 亚洲高清福利视频| 51午夜精品视频| 欧美激情一区二区三级高清视频| 日韩av免费在线播放|