系統的學習了一下angularjs,發現angularjs的有些思想根php的模塊smarty很像,例如數據綁定,filter。若是對smarty比較熟悉的話,學習angularjs會比較容易一點。這篇簡單說一下angularjs的filter功能,angularjs的filter功能可分爲二種,一種是內置的過濾器,一種是自定義的。php
一,內置的過濾器html
1,uppercase,lowercase大小轉換jquery
- {{ "lower cap string" | uppercase }}
- {{ "TANK is GOOD" | lowercase }}
|這裏的豎線是一種管道功能,若是對linux比較熟悉的話,這塊的|根linux的管道功能,基本是同樣的linux
2,json格式化angularjs
- {{ {foo: "bar", baz: 23} | json }}
注意:bza沒格式前是沒有雙引號的,格式化後就轉換成了json數據了。json
3,date格式化mvc
- {{ 1304375948024 | date }}
- {{ 1304375948024 | date:"MM/dd/yyyy @ h:mma" }}
- {{ 1304375948024 | date:"yyyy-MM-dd hh:mm:ss" }}
4,number格式化app
- {{ 1.234567 | number:1 }}
- {{ 1234567 | number }}
5,currency貨幣格式化框架
- {{ 250 | currency }}
- {{ 250 | currency:"RMB ¥ " }}
6,filter查找iphone
- {{ [{"age": 20,"id": 10,"name": "iphone"},
- {"age": 12,"id": 11,"name": "sunm xing"},
- {"age": 44,"id": 12,"name": "test abc"}
- ] | filter:'s'}}
-
-
- {{ [{"age": 20,"id": 10,"name": "iphone"},
- {"age": 12,"id": 11,"name": "sunm xing"},
- {"age": 44,"id": 12,"name": "test abc"}
- ] | filter:{'name':'iphone'} }}
-
7,limitTo字符串,對像的截取
- {{ "i love tank" | limitTo:6 }}
- {{ "i love tank" | limitTo:-4 }}
-
- {{ [{"age": 20,"id": 10,"name": "iphone"},
- {"age": 12,"id": 11,"name": "sunm xing"},
- {"age": 44,"id": 12,"name": "test abc"}
- ] | limitTo:1 }}
8,orderBy對像排序
- {{ [{"age": 20,"id": 10,"name": "iphone"},
- {"age": 12,"id": 11,"name": "sunm xing"},
- {"age": 44,"id": 12,"name": "test abc"}
- ] | orderBy:'id':true }}
-
- {{ [{"age": 20,"id": 10,"name": "iphone"},
- {"age": 12,"id": 11,"name": "sunm xing"},
- {"age": 44,"id": 12,"name": "test abc"}
- ] | orderBy:'id' }}
二,自定filter功能
我找了一個基本angularjs的mvc框架,phonecat,自定義filter也是在這基礎寫的,這個框架挺好用的。
1,filters.js添加一個module
- angular.module('tanktest', []).filter('tankreplace', function() {
- return function(input) {
- return input.replace(/tank/, "=====")
- };
- });
2,app.js中加載這個module
- var phonecatApp = angular.module('phonecatApp', [
- 'ngRoute',
- 'phonecatControllers',
- 'facebookControllers',
- 'tanktest'
- ]);
3,html中調用
- {{ "TANK is GOOD" | lowercase |tankreplace}}