AngularJS 作为一款经典的前端框架,其 Filters(过滤器)功能为数据展示提供了灵活的格式化能力,Filters 主要用于在模板中对数据进行实时转换和格式化,无需在控制器中编写额外的格式化逻辑,从而保持代码的简洁和可维护性,本文将详细介绍 AngularJS 中 Filters 的使用方法、内置过滤器及自定义过滤器的实现。
Filters 的基本使用
AngularJS 中的 Filters 主要通过在模板中使用管道符()来调用,其基本语法为
{{ Expression | filterName : parameter1 : parameter2 ... }}
。
expression
是需要处理的数据表达式,
filterName
是过滤器的名称,是传递给过滤器的可选参数,Filters 可以串联使用,
{{ expression | filter1 | filter2 : param }}
,此时数据会依次经过和的处理。
Filters 不仅可以在模板中直接使用,还可以在控制器、服务或指令中通过服务调用,在 JAVAScript 代码中使用时,需要依赖注入服务,
$filter('filterName')(expression, parameter)
。
常用内置过滤器
AngularJS 提供了多种内置过滤器,覆盖了文本格式化、数值处理、数组操作等常见场景。
文本格式化过滤器
数值处理过滤器
数组操作过滤器
集合操作过滤器
自定义 Filters 的实现
当内置过滤器无法满足需求时,可以自定义过滤器,自定义过滤器是一个工厂函数,返回一个过滤函数,接收输入数据作为第一个参数,后续参数为过滤器参数。
自定义过滤器示例
以下是一个自定义过滤器,用于将文本首字母大写:
app.filter('capitalize', function() {return function(input) {if (!input) return '';return input.charAt(0).toUpPERCase() + input.slice(1).tolowerCase();};});
在模板中使用:
{{ 'angularjs' | capitalize }}
输出。
带参数的自定义过滤器
以下是一个自定义过滤器,用于截取文本并添加省略号:
app.filter('ellipsis', function() {return function(input, length) {if (!input) return '';length = length || 10;return input.length > length ? input.substring(0, length) + '...' : input;};});
在模板中使用:
{{ 'This is a long text' | ellipsis : 5 }}
输出。
Filters 的性能优化
虽然 Filters 使用方便,但在大量数据或复杂计算场景下,可能会影响性能,以下是一些优化建议:
Filters 的应用场景
Filters 广泛应用于以下场景:
通过合理使用 AngularJS 的 Filters,可以显著提升数据展示的灵活性和代码的可读性,同时减少控制器中的业务逻辑,实现关注点分离,掌握内置过滤器的用法并学会自定义过滤器,是开发高效 AngularJS 应用的必备技能。














发表评论