Angularjs 过滤器使用

 

Filter:格式化数据

// HTML表达式:
{{ filter_expression | filter : expression : comparator}}
 
// JS表达式:
$filter('filter')(array, expression, comparator)
 

Filter是用来格式化数据用的。

Filter的基本原型( ‘|’ 类似于Linux中的管道模式):

{{ expression | filter }}

Filter可以被链式使用(即连续使用多个filter):

{{ expression | filter1 | filter2 | ... }}

Filter也可以指定多个参数:

{{ expression | filter:argument1:argument2:... }}


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)

用法:

<!--使用ISO标准日期格式 -->
{{ '2015-05-20T03:56:16.887Z' | date:"MM/dd/yyyy @ h:mma"}}

<!--使用13位(单位:毫秒)时间戳 -->
{{ 1432075948123 | date:"MM/dd/yyyy @ h:mma"}}

<!--指定timezone为UTC -->
{{ 1432075948123 | date:"MM/dd/yyyy @ h:mma":"UTC"}}

filterFilter(filter):

用途:过滤数组

方法原型:

function(array, expression, comparator)

用法1(参数expression使用String):

 <div ng-init="myArr = [{name:'Tom', age:20}, {name:'Tom Senior', age:50}, {name:'May', age:21}, {name:'Jack', age:20}, {name:'Alice', age:22}]">
     <!-- 参数expression使用String,将全文搜索关键字 'a' -->
     <div ng-repeat="u in myArr | filter:'a' ">
         <p>Name:{{u.name}}</p>
         <p>Age:{{u.age}}</p>
         <br />
     </div>
 </div>

用法2(参数expression使用function):

  // 先在Controller中定义function: myFilter
  $scope.myFilter = function (item) {
      return item.age === 20;
  };
  
  <div ng-repeat="u in myArr | filter:myFilter ">
      <p>Name:{{u.name}}</p>
      <p>Age:{{u.age}}</p>
      <br />
 </div>

用法3(参数expression使用object):

 <div ng-init="myArr = [{name:'Tom', age:20}, {name:'Tom Senior', age:50}, {name:'May', age:21}, {name:'Jack', age:20}, {name:'Alice', age:22}]">
     <div ng-repeat="u in myArr | filter:{age: 21} ">
         <p>Name:{{u.name}}</p>
         <p>Age:{{u.age}}</p>
         <br />
     </div>
 </div>

用法4(指定comparator为true或false):

  <div ng-init="myArr = [{name:'Tom', age:20}, {name:'Tom Senior', age:50}, {name:'May', age:21}, {name:'Jack', age:20}, {name:'Alice', age:22}]">
      Name:<input ng-model="yourName" />
      <!-- 指定comparator为false或者undefined,即为默认值可不传,将以大小写不敏感的方式匹配任意内容 -->
      <!-- 可以试试把下面代码的comparator为true,true即大小写及内容均需完全匹配 -->
      <div ng-repeat="u in myArr | filter:{name:yourName}:false ">
          <p>Name:{{u.name}}</p>
          <p>Age:{{u.age}}</p>
          <br />
      </div>
 </div>

用法5(指定comparator为function):

  // 先在Controller中定义function:myComparator, 此function将能匹配大小写不敏感的内容,但与comparator为false的情况不同的是,comparator必须匹配全文
  $scope.myComparator = function (expected, actual) {
      return angular.equals(expected.toLowerCase(), actual.toLowerCase());
  }
  
  <div ng-init="myArr = [{name:'Tom', age:20}, {name:'Tom Senior', age:50}, {name:'May', age:21}, {name:'Jack', age:20}, {name:'Alice', age:22}]">
      Name:<input ng-model="yourName" />
      <div ng-repeat="u in myArr | filter:{name:yourName}:myComparator ">
          <p>Name:{{u.name}}</p>
         <p>Age:{{u.age}}</p>
         <br />
     </div>
 </div>


感谢码农网  原文链接http://www.codeceo.com/article/angularjs-filter-usage.html

posted @ 2017-02-25 16:27  刘元进  阅读(2105)  评论(0编辑  收藏  举报