美文网首页我爱编程
【北京分院一百零六期】简述ANGULAR中CONSTANT和$F

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

作者: 修了个真 | 来源:发表于2017-05-10 23:45 被阅读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

    相关文章

      网友评论

        本文标题:【北京分院一百零六期】简述ANGULAR中CONSTANT和$F

        本文链接:https://www.haomeiwen.com/subject/pangtxtx.html