AngularJs過濾器

在AngularJS中使用過濾器格式化展示數據,在“{{}}”中使用“|”來調用過濾器,使用“:”傳遞參數。

1、內置過濾器

  • currency:將數值格式化為貨幣格式
<body ng-app="app">
<ul ng-controller="DemoController">
    <li>默認為美元符號:{{price|currency}}</li>
    <li>用冒號傳值¥:{{price|currency:'¥'}}</li>
</ul>
<!--引入angularjs-->
<script src="js/angular.min.js"></script>
<script>
    var app = angular.module("app",[]);
    app.controller("DemoController",['$scope',function ($scope) {
        $scope.price = 11.11;
    }])
</script>
</body>
將數值格式化為貨幣
  • date:日期格式化,年(y)、月(M)、日(d)、星期(EEEE/EEE)、時(H/h)、分(m)、秒(s)、毫秒(.sss),也可以組合到一起使用。
<body ng-app="app">
<ul ng-controller="DemoController">
    <li>時間:{{now|date:'yyyy-MM-dd h:mm:ss '}}</li>
</ul>
<!--引入angularjs-->
<script src="js/angular.min.js"></script>
<script>
    var app = angular.module("app",[]);
    app.controller("DemoController",['$scope',function ($scope) {
        $scope.now = new Date();
    }])
</script>
</body>
格式化時間
  • filter:在給定數組中選擇滿足條件的一個子集,并返回一個新數組,其條件可以是一個字符串、對象、函數
<body ng-app="app">
<ul ng-controller="DemoController">
    <!--過濾出items數組中含有s的字符串-->
    <li>{{items|filter:'s'}}</li>
    <!--過濾出年齡為20的人-->
    <li>{{student|filter:{age:20} }}</li>
</ul>
<!--引入angularjs-->
<script src="js/angular.min.js"></script>
<script>
    var app = angular.module("app",[]);
    app.controller("DemoController",['$scope',function ($scope) {
        $scope.items = ['html','js','jq','css','student'];
        $scope.student = [
            {name:'小明',age:19},
            {name:'小李',age:20},
            {name:'張三',age:20}
        ]
    }])
</script>
</body>
過濾字符串和對象
  • json:將Javascrip對象轉成JSON字符串
<body ng-app="app">
<ul ng-controller="DemoController">
    <li>轉化為json對象:{{student|json}}</li>
</ul>
<!--引入angularjs-->
<script src="js/angular.min.js"></script>
<script>
    var app = angular.module("app",[]);
    app.controller("DemoController",['$scope',function ($scope) {
        $scope.student = [
            {name:'小明',age:19},
            {name:'小李',age:20},
            {name:'張三',age:20}
        ]
    }])
</script>
</body>
轉化為json
  • limitTo:取出字符串或數組的前(正數)幾位或后(負數)幾位
<body ng-app="app">
<ul ng-controller="DemoController">
    <li>截取數組items的第一個和最后一個元素:{{items|limitTo:1}},{{items|limitTo:-1}}</li>
</ul>
<!--引入angularjs-->
<script src="js/angular.min.js"></script>
<script>
    var app = angular.module("app",[]);
    app.controller("DemoController",['$scope',function ($scope) {
        $scope.items = ['html','js','jq','css','student'];
    }])
</script>
</body>
Paste_Image.png
  • lowercase:將文本轉換成小寫格式,uppercase:將文本轉換成大寫格式
<body ng-app="app">
<ul ng-controller="DemoController">
    <li>將str2轉化為小寫:{{str2|lowercase}}</li>
    <li>將str1轉化為大寫:{{str1|uppercase}}</li>
</ul>
<!--引入angularjs-->
<script src="js/angular.min.js"></script>
<script>
    var app = angular.module("app",[]);
    app.controller("DemoController",['$scope',function ($scope) {
        $scope.str1 = 'ddddddddddddhello';
        $scope.str2 = 'HELLODDDDDDDDDDDDDDDDDDDDDDDDDDDD';
    }])
</script>
</body>
字符串大小寫轉化
  • number:數字格式化,可控制小位位數
<body ng-app="app">
<ul ng-controller="DemoController">
  <!--將str3轉化為數字,并保留四位小數-->
    <li>{{str3|number:4}}</li>
</ul>
<!--引入angularjs-->
<script src="js/angular.min.js"></script>
<script>
    var app = angular.module("app",[]);
    app.controller("DemoController",['$scope',function ($scope) {
        $scope.str3 = '45678.22'
    }])
</script>
</body>
Paste_Image.png
  • orderBy:對數組進行排序,第2個參數可控制方向
<body ng-app="app">
<ul ng-controller="DemoController">
    <li>{{items|orderBy:'':true}}</li>
    <!--如果數組中村的時對象的話,可以按照某個屬性值排序,true是降序,false是升序-->
    <li>{{student|orderBy:'age':true}}</li>
</ul>
<!--引入angularjs-->
<script src="js/angular.min.js"></script>
<script>
    var app = angular.module("app",[]);
    app.controller("DemoController",['$scope',function ($scope) {
        $scope.items = ['html','js','jq','css','student'];
        $scope.student = [
            {name:'小明',age:19},
            {name:'小李',age:20},
            {name:'張三',age:20}
        ]
    }])
</script>
</body>
Paste_Image.png

2、自定義過濾器

當我們內置的過濾器不能滿足我們的需求時,我們可以自定義過濾器,AngularJs也支持自定義過濾器。

 app.filter('capitalize',function () {
        return function () {
        }
    });

使用app.filter()方法 自定義過濾器,其中兩個參數,一個表示過濾器的名稱,一個表示返回的函數,接下來,寫一個小Demo來定義一個把英文字符串首字母轉化為大寫的過濾器。

<body ng-app="app">
<ul ng-controller="demoController">
    <h4>將首字母轉化為大寫:{{info|capitalize}}</h4>
</ul>
<!--引入angularjs-->
<script src="js/angular.min.js"></script>
<script>
    var app = angular.module("app",[]);
//    定義過濾器,第一個參數表示過濾器的名稱
    app.filter('capitalize',function () {
        return function (input) {
//    將字符串的第一個字母變為大寫
           return input[0].toUpperCase()+input.slice(1)
        }
    });
    app.controller("demoController",["$scope",function ($scope) {
          $scope.info ="my name is huangsen";
    }])
</script>
</body>

在這里需要傳遞一個input參數來接收,本來過濾器的哪個豎線就是相當于一個管道,這里的input就相當于傳遞過來的內容。

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 230,321評論 6 543
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,559評論 3 429
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 178,442評論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,835評論 1 317
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,581評論 6 412
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,922評論 1 328
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,931評論 3 447
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 43,096評論 0 290
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,639評論 1 336
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,374評論 3 358
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,591評論 1 374
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,104評論 5 364
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,789評論 3 349
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,196評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,524評論 1 295
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,322評論 3 400
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,554評論 2 379

推薦閱讀更多精彩內容