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配置本地域名,如何让电脑通过自定义域名访问本地站点?

    在本地开发环境中,使用自定义域名替代默认的 localhost 或 127.0.0.1,可以更真实地模拟生产环境,提升开发效率,本文将详细介绍如何通过 Apache 服务器配置本地域名,包括环境准备、配置步骤、常见问题解决及高级技巧,帮助开发者快速搭建本地域名解析环境,环境准备与基础配置在开始配置前,需确保系统……

    2025年10月31日
    090
  • AngularJS内置指令有哪些实用技巧?新手必看指南

    AngularJS作为一款经典的前端JavaScript框架,其强大的指令系统是构建动态单页应用的核心,内置指令作为AngularJS预定义的HTML扩展属性,极大地简化了DOM操作和数据绑定的复杂度,本文将详细介绍常用内置指令的功能、语法及实际应用场景,帮助开发者高效掌握AngularJS的核心特性,数据绑定……

    2025年11月2日
    030
  • 在玉溪本地租用服务器,哪家价格便宜又稳定?

    在数字化浪潮席卷全球的今天,服务器作为数据存储、处理和网络服务的核心基础设施,其重要性不言而喻,对于正在积极拥抱数字经济的玉溪本地企业而言,选择合适的服务器解决方案,是决定其业务能否高效、安全运行的关键一步,相较于遥远的云端数据中心,部署在玉溪本地的服务器,正以其独特的优势,成为越来越多本地企业的首选,服务器的……

    2025年10月23日
    080
  • AngularJS过滤器详解,如何灵活使用过滤器的具体方法?

    AngularJS 作为一款经典的前端框架,其强大的数据绑定和依赖注入特性为开发者提供了极大的便利,在 AngularJS 的核心功能中,过滤器(Filter)扮演着至关重要的角色,它能够对数据进行格式化、筛选和转换,使数据显示更加灵活和直观,本文将详细讲解 AngularJS 过滤器的基本概念、使用方法、内置……

    2025年11月3日
    060

发表回复

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