我爱编程

【北京分院一百零六期】简述ANGULAR中CONSTANT和$F

2017-05-10  本文已影响0人  修了个真

简述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)

更多详细信息可以参考官方文档 这里

编码实战

见最下视频↓

更多思考

为什么过滤器不需要引入就可以直接使用?

参考资料

AngularJS constant和value

AngularJS的Filter用法详解


视频链接:https://v.qq.com/x/page/k0501icb2hf.html

ppt链接:https://ptteng.github.io/PPT/PPT/js-07-angular-constant-and-$filter.html

上一篇下一篇

猜你喜欢

热点阅读