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

相关推荐

  • apache如何正确整合php实现动态网页解析?

    在Web开发领域,Apache与PHP的整合是构建动态网站的核心技术之一,Apache作为全球最流行的Web服务器软件,以其稳定性、灵活性和开源特性著称;PHP则是一种广泛使用的服务器端脚本语言,特别适合Web开发,两者的结合能够实现高效的动态内容处理,为用户提供丰富的交互体验,以下将从环境准备、安装配置、整合……

    2025年10月22日
    0670
  • 服务器路由端口映射怎么设置?内网穿透外网访问详细步骤

    服务器路由端口映射在现代网络架构中,服务器路由端口映射是连接内网与外网、实现服务访问的核心技术,无论是搭建网站、部署应用程序,还是进行远程管理,端口映射都扮演着不可或缺的角色,本文将深入解析服务器路由端口映射的原理、配置方法、常见应用场景及注意事项,帮助读者全面理解这一技术,端口映射的基本概念端口映射(Port……

    2025年11月10日
    01380
  • 平流式沉淀池高度计算公式是什么?如何准确计算其池体高度?

    平流式沉淀池高度的计算方法与应用解析平流式沉淀池是水处理工艺中核心的重力沉降设备,通过水平水流使悬浮颗粒在重力作用下沉降分离,广泛应用于城市污水处理、工业废水处理及饮用水预处理等领域,其结构包含进水区、沉淀区、出水区、污泥区等,其中沉淀区高度是决定处理效果的关键参数——若高度不足,会导致悬浮颗粒未充分沉降,出水……

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

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

      2026年1月10日
      020
  • 服务器如何查看备份文件?

    服务器查看备份的重要性与操作指南在信息化时代,数据已成为企业运营的核心资产,服务器作为数据存储与处理的关键载体,其备份状态直接关系到数据安全与业务连续性,定期查看服务器备份情况,不仅能确保备份策略的有效执行,还能在数据丢失或系统故障时快速恢复,降低损失,本文将详细介绍服务器查看备份的意义、常用方法、操作步骤及注……

    2025年12月25日
    0810

发表回复

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