【北京分院一百零六期】简述ANGULAR中CONSTANT和$F
简述ANGULAR中CONSTANT和$FILTER的用法
背景介绍
angular是什么,这里不再叙述。
constant,可以算作angular的全局数据,想要使用的话,只需要在控制器注入即可。
$filter,angular的过滤器,如果想要在控制器里面使用,也是注入,然后调用,而html中的数据过滤,直接键入过滤器名称和对应值即可。
知识剖析
constant:
每当搜索constant时候,总会连带出现value的说明。
两者都可以作为全局变量使用,但是有两点不同:
value不可以在config里注入,但是constant可以。
value可以修改,但是constant不可以修改,一般直接用constant配置一些需要经常使用的数据。
下面是简单的应用例子:
angular.module('myApp', [])
.constant('apiKey','123123123')
.value('FBid','231231231')
.controller('myController',function($scope,apiKey,FBid){
$scope.a = apiKey;
$scope.b = FBid;
})
.config(function(apiKey) {
// 在这里apiKey将被赋值为123123123// 就像上面设置的那样
})
.config(function(FBid) {
// 这将抛出一个错误,未知的provider: FBid
// 因为在config函数内部无法访问这个值
});
Filter
Filter是用来格式化数据用的。
Filter的基本原型( '|' 类似于Linux中的管道模式):
{{ expression | filter }}
Filter可以被链式使用(即连续使用多个filter):
{{ expression | filter1 | filter2 | ... }}
Filter也可以指定多个参数:
{{expression|filter:argument1:argument2:...}}
AngularJS内建的Filter
AngularJS内建了一些常用的Filter,我们一一来看一下。
currencyFilter(currency):
用途:格式化货币
方法原型:
function(amount, currencySymbol, fractionSize)
用法
{{ 12 | currency}} //将12格式化为货币,默认单位符号为 ', 小数默认2位
{{ 12.45 | currency:'¥'}} //将12.45格式化为货币,使用自定义单位符号为 '¥', 小数默认2位
{{ 12.45 | currency:'CHY¥':1}} //将12.45格式化为货币,使用自定义单位符号为 'CHY¥', 小数指定1位, 会执行四舍五入操作
{{ 12.55 | currency:undefined:0}} //将12.55格式化为货币, 不改变单位符号, 小数部分将四舍五入
dateFilter(date):
用途:格式化日期
方法原型:
function(date, format, timezone)
用法
{{ '2015-05-20T03:56:16.887Z' | date:"MM/dd/yyyy @ h:mma"}} //使用ISO标准日期格式
{{ 1432075948123 | date:"MM/dd/yyyy @ h:mma"}} //使用13位(单位:毫秒)时间戳
{{ 1432075948123 | date:"MM/dd/yyyy @ h:mma":"UTC"}} //指定timezone为UTC
jsonFilter(json):
方法原型:
function(object, spacing)
用法(将对象格式化成标准的JSON格式):
{{ {name:'Jack', age:21} | json}}
自定义Filter
和Directive一样,如果内建的Filter不能满足你的需求,你当然可以定义一个专属于你自己的Filter。我们来做一个自己的Filter:capitalize_as_you_want,该Filter会使你输入的字符串中的首字母、指定index位置字母以及指定的字母全部大写。
function(input, capitalize_index, specified_char)
更多详细信息可以参考官方文档 这里
编码实战
见最下视频↓
更多思考
为什么过滤器不需要引入就可以直接使用?
参考资料
视频链接:https://v.qq.com/x/page/k0501icb2hf.html
ppt链接:https://ptteng.github.io/PPT/PPT/js-07-angular-constant-and-$filter.html