系统的学习了一下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}}