AngularJS过滤器怎么用?入门教程示例详解

AngularJS 作为一款经典的前端框架,其过滤器(Filter)功能为数据展示提供了便捷的格式化方式,本文将通过基础概念、常用过滤器示例及自定义过滤器编写,带你快速掌握 AngularJS 过滤器的核心用法。

AngularJS过滤器怎么用?入门教程示例详解

过滤器基础概念

过滤器在 AngularJS 中主要用于对数据进行格式化处理,通常在模板中通过管道符()调用,其基本语法为 {{ expression | filterName : parameter1 : parameter2 ... }}expression 为需要处理的数据,filterName 为过滤器名称,parameter 为可选参数,过滤器可串联使用,也可应用于指令(如 ng-repeat)中的数据。

常用过滤器示例

格式化过滤器

  • currency:将数字转换为货币格式。
    示例:{{ 1234.56 | currency : "¥" : 0 }}
    输出:¥1235(参数1为货币符号,参数2为小数位数)

  • date:格式化日期对象。
    示例:{{ dateValue | date : "yyyy-MM-dd HH:mm:ss" }}
    输出:2023-10-01 15:30:00(参数为日期格式模板)

  • number:格式化数字。
    示例:{{ 0.12345 | number : 2 }}
    输出:12(参数为小数位数)

数组/对象过滤器

  • filter:根据条件筛选数组。
    示例:<li ng-repeat="user in users | filter : {age : '>20'}">{{ user.name }}</li>
    作用:筛选 age 大于 20 的用户。

  • orderBy:对数组进行排序。
    示例:<li ng-repeat="user in users | orderBy : '-age'">{{ user.name }}</li>
    作用:按 age 降序排列( 表示降序)。

    AngularJS过滤器怎么用?入门教程示例详解

  • limitTo:截取数组或字符串。
    示例:{{ "Hello Angular" | limitTo : 5 }}
    输出:Hello

字符串处理过滤器

  • uppercase/lowercase:转换大小写。
    示例:{{ "angular" | uppercase }}
    输出:ANGULAR

  • json:将对象转换为 JSON 字符串(便于调试)。
    示例:{{ {name: "Tom", age: 20} | json }}
    输出:{"name":"Tom","age":20}

自定义过滤器

当内置过滤器无法满足需求时,可自定义过滤器,通过模块的 filter 方法注册,语法如下:

angular.module('myApp', [])
  .filter('reverse', function() {
    return function(input) {
      return input.split('').reverse().join('');
    };
  });

模板中使用方式:{{ "hello" | reverse }}
输出:olleh

自定义过滤器支持依赖注入,

AngularJS过滤器怎么用?入门教程示例详解

.filter('greet', function() {
  return function(name) {
    return "Hello, " + name + "!";
  };
});

使用:{{ "World" | greet }}
输出:Hello, World!

过滤器在指令中的综合应用

以下是一个结合 ng-repeat 和多个过滤器的示例,展示用户列表的筛选、排序和格式化:

<div ng-app="userApp" ng-controller="UserCtrl">
  <input type="text" ng-model="searchText" placeholder="搜索用户名">
  <select ng-model="sortOrder">
    <option value="name">按姓名排序</option>
    <option value="-age">按年龄降序</option>
  </select>
  <ul>
    <li ng-repeat="user in users | filter : searchText | orderBy : sortOrder">
      {{ user.name | uppercase }} - {{ user.age | number }}岁 - 加入时间:{{ user.joinDate | date : "yyyy年MM月dd日" }}
    </li>
  </ul>
</div>

对应控制器:

angular.module('userApp', [])
  .controller('UserCtrl', function($scope) {
    $scope.users = [
      {name: "Alice", age: 25, joinDate: new Date("2022-01-15")},
      {name: "Bob", age: 30, joinDate: new Date("2021-05-20")},
      {name: "Carol", age: 28, joinDate: new Date("2022-03-10")}
    ];
  });

注意事项

  1. 性能优化:避免在大量数据(如 ng-repeat)中使用复杂过滤器,可能导致性能问题。
  2. 不可变性:过滤器返回新对象,不会修改原始数据。
  3. 版本差异:AngularJS 1.x 与 Angular(2+)的过滤器语法完全不同,需注意区分。

通过本文的示例,相信你已经掌握了 AngularJS 过滤器的核心用法,合理运用过滤器,能显著提升数据展示的灵活性和代码的可读性,为前端开发带来便利。

图片来源于AI模型,如侵权请联系管理员。作者:酷小编,如若转载,请注明出处:https://www.kufanyun.com/ask/51872.html

(0)
上一篇 2025年11月3日 06:10
下一篇 2025年11月3日 06:12

相关推荐

  • 负载均衡节点在云计算中扮演何种关键角色?

    负载均衡节点作为现代分布式系统架构中的核心组件,承担着流量调度、故障转移和资源优化的关键职责,在实际工程实践中,负载均衡节点的设计与部署直接影响着整个系统的可用性、性能表现以及运维复杂度,从架构演进的角度来看,负载均衡节点经历了从硬件负载均衡器到软件定义负载均衡的显著转变,早期企业普遍采用F5、A10等专用硬件……

    2026年2月12日
    060
  • 服务器根目录在哪?新手如何快速找到服务器根目录路径?

    在网站开发和服务器管理中,“服务器根目录”是一个基础且至关重要的概念,服务器根目录是网站文件存储的顶层目录,也是用户通过浏览器访问网站时,服务器默认查找文件的起始位置,理解根目录的位置及其作用,对于网站部署、文件管理和故障排查都具有重要的指导意义,服务器根目录的定义与作用服务器根目录可以理解为网站在服务器上的……

    2025年12月20日
    01010
    • 服务器间歇性无响应是什么原因?如何排查解决?

      根源分析、排查逻辑与解决方案服务器间歇性无响应是IT运维中常见的复杂问题,指服务器在特定场景下(如高并发时段、特定操作触发时)出现短暂无响应、延迟或服务中断,而非持续性的宕机,这类问题对业务连续性、用户体验和系统稳定性构成直接威胁,需结合多维度因素深入排查与解决,常见原因分析:从硬件到软件的多维溯源服务器间歇性……

      2026年1月10日
      020
  • 长沙市服务器一月为何价格波动如此大?揭秘一月市场动态之谜!

    市场概况1 服务器需求增长随着互联网的快速发展,长沙市的服务器需求呈现出持续增长的趋势,根据最新数据显示,长沙市服务器市场在2023年1月份的销售额较去年同期增长了15%,这一增长主要得益于企业数字化转型和云计算市场的扩大,2 市场竞争加剧在长沙市,服务器市场竞争日益激烈,各大品牌纷纷加大在长沙市的投入,以争夺……

    2025年12月5日
    0730
  • 如何有效应对和防范DDos攻击的最佳策略与工具?

    防DDoS攻击:全面攻略指南了解DDoS攻击DDoS(Distributed Denial of Service)攻击,即分布式拒绝服务攻击,是一种通过网络向目标服务器发送大量请求,使服务器资源耗尽,无法正常响应合法用户请求的攻击方式,了解DDoS攻击的原理和类型,是有效防御的第一步,DDoS攻击的类型网络带宽……

    2026年1月23日
    0350

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注