AngularJS过滤器有哪些常见用法及注意事项?

AngularJS基础知识笔记之过滤器

AngularJS过滤器有哪些常见用法及注意事项?

在AngularJS开发中,过滤器是一个核心功能,主要用于对数据进行格式化或转换,使其在视图中以更友好的方式展示,过滤器可以应用于表达式、指令以及自定义模板中,通过管道符()调用,语法简洁且功能强大,本文将详细介绍AngularJS过滤器的使用方法、内置过滤器类型、自定义过滤器的实现以及常见应用场景。

过滤器的基本语法与调用方式

AngularJS过滤器的调用方式非常灵活,主要分为以下几种:

  1. 在模板中直接调用
    最常见的使用场景是在模板中通过表达式结合管道符调用过滤器,格式化日期:

    <p>{{ birthday | date:'yyyy-MM-dd' }}</p>  

    date是过滤器名称,'yyyy-MM-dd'是传递给过滤器的参数。

  2. 在指令中使用
    过滤器也可以与指令结合使用,例如在ng-repeat中对列表数据进行筛选和排序:

    <li ng-repeat="item in items | filter:searchText | orderBy:'name'">  
      {{ item.name }}  
    </li>  

    这里同时使用了filterorderBy两个过滤器,按顺序对数据进行处理。

  3. 在控制器或服务中调用
    通过依赖注入$filter服务,可以在JavaScript代码中手动调用过滤器:

    app.controller('DemoController', function($scope, $filter) {  
      $scope.formattedDate = $filter('date')(new Date(), 'yyyy-MM-dd');  
    });  

内置过滤器详解

AngularJS提供了多种内置过滤器,覆盖了数据处理中的常见需求,以下是常用过滤器的功能及示例:

AngularJS过滤器有哪些常见用法及注意事项?

currency:货币格式化

将数字转换为货币格式,支持指定符号和小数位数。

<p>{{ price | currency:'¥' }}</p>  
<!-- 输出:¥123.45 -->  

date:日期格式化

对日期对象或时间戳进行格式化,支持多种格式化模式。

<p>{{ now | date:'yyyy年MM月dd日 HH:mm:ss' }}</p>  
<!-- 输出:2023年10月01日 14:30:00 -->  

filter:数据筛选

根据条件对数组或对象进行筛选,支持字符串、对象或函数作为筛选条件。

<input ng-model="searchText">  
<li ng-repeat="user in users | filter:searchText">  
  {{ user.name }}  
</li>  

orderBy:排序

对数组进行排序,支持按字段名或自定义排序函数排序。

<li ng-repeat="user in users | orderBy:'age':true">  
  {{ user.name }} - {{ user.age }}  
</li>  
<!-- true表示降序 -->  

lowercaseuppercase:大小写转换

将字符串转换为全小写或全大写。

<p>{{ message | lowercase }}</p>  
<p>{{ message | uppercase }}</p>  

number:数字格式化

对数字进行格式化,可指定小数位数或千位分隔符。

<p>{{ 1234567.891 | number:2 }}</p>  
<!-- 输出:1,234,567.89 -->  

limitTo:截取数组或字符串

限制数组或字符串的长度,支持正数(从头截取)和负数(从尾截取)。

<p>{{ 'Hello' | limitTo:3 }}</p>  
<!-- 输出:Hel -->  

json:JSON格式化

将JavaScript对象转换为JSON字符串,常用于调试。

AngularJS过滤器有哪些常见用法及注意事项?

<pre>{{ user | json }}</pre>  

自定义过滤器

当内置过滤器无法满足需求时,可以自定义过滤器,自定义过滤器通过module.filter()方法注册,本质上是一个函数,接收输入值并返回处理后的结果。

示例:自定义过滤器实现文本截断

app.filter('truncate', function() {  
  return function(input, length) {  
    if (!input) return '';  
    length = length || 10;  
    return input.length > length ? input.substring(0, length) + '...' : input;  
  };  
});  

在模板中使用:

<p>{{ longText | truncate:20 }}</p>  

高级自定义过滤器:带参数的过滤器

自定义过滤器可以接收多个参数,例如实现一个根据状态筛选数据的过滤器:

app.filter('statusFilter', function() {  
  return function(items, status) {  
    if (!status) return items;  
    return items.filter(function(item) {  
      return item.status === status;  
    });  
  };  
});  

模板调用:

<li ng-repeat="item in items | statusFilter:'active'">  
  {{ item.name }}  
</li>  

过滤器的链式调用与性能优化

AngularJS支持多个过滤器链式调用,按从左到右的顺序执行。

<p>{{ data | filter:search | orderBy:'date' | limitTo:5 }}</p>  

性能优化建议

  1. 避免在大型数据集上使用复杂过滤器:过滤器会在每次$digest周期中重新计算,可能影响性能。
  2. 使用track by优化ng-repeat:结合过滤器时,为ng-repeat添加track by可减少DOM操作。
  3. 缓存过滤结果:对于不常变化的数据,可在控制器中预先过滤并存储结果。

过滤器的常见应用场景

  1. 表格数据的实时筛选与排序:通过filterorderBy实现动态数据展示。
  2. 表单数据的格式化:如日期、金额的输入格式化与显示格式化分离。
  3. 多语言支持:结合自定义过滤器实现文本的国际化转换。
  4. 数据脱敏:如手机号、身份证号的隐藏显示。

内置过滤器参数速查表

过滤器名称 功能 示例参数
currency 货币格式化 symbol:'¥', fractionSize:2
date 日期格式化 'yyyy-MM-dd', 'short'
filter 数据筛选 {name:'John'}, 'text'
orderBy 排序 'name', reverse:true
number 数字格式化 2(小数位数)
limitTo 截取 5, -3

过滤器是AngularJS中处理数据展示的重要工具,通过内置过滤器可以快速实现常见的数据格式化需求,而自定义过滤器则提供了灵活的扩展能力,合理使用过滤器,不仅能提升代码的可读性,还能简化数据逻辑的处理,在实际开发中,需注意过滤器的性能影响,避免在频繁变化的数据上使用复杂计算,以确保应用的流畅运行。

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

(0)
上一篇 2025年11月4日 15:44
下一篇 2025年11月4日 15:48

相关推荐

  • 服务器设备管理器处理器如何高效监控与管理?

    服务器设备管理器中的处理器核心管理在现代数据中心和企业IT架构中,服务器作为核心承载设备,其稳定性和性能直接关系到业务连续性,而处理器(CPU)作为服务器的“大脑”,其管理效率直接影响整体计算能力,服务器设备管理器(Server Device Manager)作为硬件监控与管理的关键工具,通过集中化、智能化的方……

    2025年12月1日
    01160
  • 服务器账号怎么设置?新手必看详细步骤教程

    服务器账号设置方法账号规划与安全策略制定在设置服务器账号前,需先明确账号规划与安全策略,这是保障系统稳定运行的基础,账号规划需遵循最小权限原则,即每个账号仅获得完成其任务所必需的权限,管理员账号用于系统维护,运维账号用于日常操作,开发账号用于代码部署,普通用户账号用于访问特定服务,需避免使用默认账号(如root……

    2025年11月17日
    01170
  • 服务器用什么风扇?噪音与散热如何平衡?

    关键考量因素与技术解析在现代数据中心和企业IT基础设施中,服务器作为核心计算设备,其稳定运行离不开高效的散热系统,而风扇作为散热系统的“心脏”,直接影响服务器的性能、寿命及能耗,选择合适的服务器风扇需综合考虑散热需求、噪音控制、兼容性、可靠性及成本等多重因素,本文将从风扇类型、技术参数、应用场景及未来趋势等方面……

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

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

      2026年1月10日
      020
  • 云南服务器网站运营现状及未来发展前景如何?

    在互联网高速发展的今天,服务器网站已经成为企业展示形象、拓展业务的重要平台,云南省,作为中国西南地区的重要经济和文化中心,其服务器网站的建设与发展也日益受到重视,本文将详细介绍云南服务器网站的特点、优势以及相关应用,云南服务器网站的特点丰富的自然资源云南拥有丰富的自然资源,如秀美的山水、独特的民族风情等,服务器……

    2025年11月16日
    01090

发表回复

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