【angularJS】Filter 过滤器

  当从后台获取到的数据呈现到视图上时,此时可能需要对数据进行相应的转换,此时我们可以通过过滤器在不同页面进行不同数据的格式抓换,在AngularJS中有常见默认的过滤器,当然若不满足所需,我们可以自定义过滤器。

AngularJS 过滤器可以用来格式化数据,过滤器能够用在表达式和指令中。

使用一个管道字符(|)添加到表达式和指令中。

默认过滤器

列举AngularJS中常见的过滤器,如下:


过滤器名称


描述


例子


currency


money格式化


{{ p.price | currency}}


date


日期格式化

[orderDate为時間類型才行,不能是时间字符串]


{ p.orderDate | date : “dd MMM yyyy” }}

可以是| date : ‘yyyy年MM月dd日‘

{{ p.orderDate | date : “shortDate” }}


json


将JSON字符串生成一个JSON对象


<tr ng-repeat="p in products">

<td colspan="4">{{p | json}}</td>

</tr>


number


格式化数值并给出精确度位数


{{ p.price | number : 0}}

{{ p.price | number : 2}}


uppercase

lowercase


大小写转换


{{ p.city | lowercase }}

{{ p.state | uppercase }}


limitTo


控制列表渲染数据。限制数组长度或字符串长度


<tr ng-repeat="p in products | limitTo:10">


orderBy


排序


<tr ng-repeat="p in products | orderBy : ‘name’”>

For descending order

<tr ng-repeat="p in products | orderBy : ‘-name’”>

filter(匹配子串)

这个名叫filter的filter(不得不说这名字起的,真让人容易混淆——!)

用来处理一个数组,然后可以过滤出含有某个子串的元素,作为一个子数组来返回。可以是字符串数组,也可以是对象数组。如果是对象数组,可以匹配属性的值。它接收一个参数,用来定义子串的匹配规则。下面举个例子说明一下参数的用法,我用现在特别火的几个孩子定义了一个数组:

$scope.childrenArray = [

{name:‘kimi‘,age:3},

{name:‘cindy‘,age:4},

{name:‘anglar‘,age:4},

{name:‘shitou‘,age:6},

{name:‘tiantian‘,age:5}

];

$scope.func = function(e){return e.age>4;}

{{ childrenArray | filter : ‘a‘ }} //匹配属性值中含有a的

{{ childrenArray | filter : 4 }} //匹配属性值中含有4的

{{ childrenArray | filter : {name : ‘i‘} }} //参数是对象,匹配name属性中含有i的

{{childrenArray | filter : func }} //参数是函数,指定返回age>4的

自定义过滤器

AngularJS不仅仅支持内部自构建的过滤器,而且还可以自定义过滤器来满足我们所需,若自定义过滤器此时我们需要 通过module.filter来实现,实际上内部是通过FilterProvider来实现。module.filter这个方法有两个参数,一个是需要创建的过滤器的名称,另外一个是创建一个factory函数来使得该自定义过滤器生效或者工作。

接下来我们实现一个自定义过滤器,该过滤器带一个参数(reverse),实现了再对照代码就明朗了。如下:

app.filter("properCase", function () {
    return function (value, reverse) {  //value是需要使用过滤器的对象
        if (angular.isString(value)) {
            var intermediate = reverse == false ? value.toUpperCase() : value.toLowerCase();
   return (reverse == false ? intermediate[0].toLowerCase() :intermediate[0].toUpperCase())
+ intermediate.substr(1);
        } else {
            return value;
        }
    };
});

接下来在视图中将绑定的名称和类别修改成如下:

value | filter:reverse

<td>{{p.name | properCase}}</td>  //首字母大写

<td>{{p.category | properCase : false}}</td>  //首字母小写

混合过滤器

当进行渲染数据时,有可能需要进行多次过滤此时我们就需要创建多个自定义过滤器或者内置过滤器和自定义过滤器混合使用。

<tr ng-repeat="p in products | orderBy :‘name‘ | skipRec:2">

原文地址:https://www.cnblogs.com/peterYong/p/10106687.html

时间: 2024-10-10 17:50:15

【angularJS】Filter 过滤器的相关文章

AngularJS Filter(过滤器)用法

一.在视图模板(View Template)中使用 在表达式中应用Filters (过滤器) 需要遵循格式如下: {{ expression | filter }}        即         {{ 表达式 | 过滤器 }} 例如:{{ 12 | currency }}     输出为    $12.00 在输出结果中应用Filters (过滤器) 通俗点讲就是Filter的叠加--前一filter的输出结果作为后一filter的输入数据源. 需要遵循格式如下: {{ expression

AngularJS学习--- 过滤器(filter),格式化要显示的数据 step 9

1.切换目录,启动项目 git checkout step-9 npm start 2.需求: 格式化要显示的数据. 比如要将true-->yes,false-->no,这样相互替换. 3.效果: 4.代码实现: 这里主要是使用filter过滤器来进行数据过滤,这里只是在前端进行数据过滤,原始数据是不发生变化的. $filter:Filters are used for formatting data displayed to the user,格式化要显示的数据. 用法: {{ expres

AngularJs(八) 过滤器filter创建

大纲 示例 过滤器的使用 创建过滤器 demo 这是整个示例demo 1.filter.js文件 angular.module("exampleApp", []) .constant("productsUrl", "http://localhost:27017/products") .controller("defaultCtrl", function ($scope, $http, productsUrl) { $http.

angularJS的过滤器!

angularJS过滤器: filter currency date filter json limitTo lowercase number orderBy uppercase ...... Filter过滤器: 过滤器的主要用途就是一个格式化 / 筛选数据的小工具: 一般用于服务端存储的数据转换为用户界面可以理解的数据: 常见需要使用Filter的数据有: - 时间 1288323623006 currency:它是用来过滤货币: 作用把数字过滤成 一个货币: 使用:竖杠+过滤器名称 <di

AngularJs Filter

Filter 公司一直比较忙.. 很忧伤. 终于有点儿闲暇继续看会书 写会笔记. Filter 顾名思义 就是过滤器. 比如 排序,筛选,格式化等等. 有三种方法. 后台 JavaScript 原生 {{ data | fitler }} 如果用 angularjs 大概就这三种. 区别 后台 单次传输多,多次传输就很不划算,每次都请求. 前台. 一次传输的数据较多. JavaScript 或者 {{}} 无非是 Controller 是否重用的问题. 格式 {{ dataSource | fi

AngularJS开发指南13:AngularJS的过滤器详解

AngularJS过滤器是用来格式化输出数据的.除了格式化数据,过滤器还能修改DOM.这使得过滤器通常用来做些如“适时的给输出加入CSS样式”等工作. 比如,你可能有些数据在输出之前需要根据进行本地化.你可以向下面这样使用链式的过滤器来传递表达式: name | uppercase 这个表达式执行时会将name的值传递给uppercase过滤器. 写一个你自己的过滤器非常容易:在你的模块中注册一个新的过滤器(可注入的)工厂函数就行了.这个工厂函数必须返回一个新的过滤器函数,这个过滤函数的第一个参

AngularJS之过滤器

AnularJS的过滤器用来格式化需要展示给用户的数据,有很多实用的内置过滤器,也可以自己编写. 在HTML中的模板绑定符号{{ }}内通过|符号来调用过滤器.例如,假设我们希望将字符串转换成大写,可以对字符串中的每个字符都单独进行转换操作,也可以使用过滤器: {{ name | uppercase }} 在JavaScript代码中可以通过$filter来调用过滤器.例如,在JavaScript代码中使用lowercase过滤器: app.controller('DemoController'

estore商城案例(三)------Filter过滤器:自动登录&amp;权限管理

前面写好了用户登录\注册\添加商品的功能模块.下面写一下对于这些功能模块的相关过滤器---自动登录与权限管理: 一.自动登录: 业务逻辑是这样的:jsp登录页面有个“自动登录选项”,如果登录这勾选了,那么在serlvet程序中则会额外的生成一个保存用户名和密码的cookie,然后每次用户向服务器发送请求时,Filter过滤器都会先判断用户的登录状态(session),如果已经登录那么无需做出受任何操作直接放行,如果没有登录(无session),那么这时体现自动登录功能作用的时候到了,先获取自动登

Java Web总结十九Filter过滤器

一.Filter简介 Filter也称之为过滤器,它是Servlet技术中最激动人心的技术,Web开发人员通过Filter技术,对Web服务器管理的所有Web资源:例如Jsp,Servlet,静态图片文件或静态HTML文件等进行拦截,从而实现一些特殊的功能.例如实现URL级别的权限访问控制.过滤敏感词汇.自动登录.压缩响应信息等一些高级功能. Servlet API中提供了一个Filter接口,开发Web应用时,如果编写的Java类实现了这个接口,则把这个Java类称之为过滤器Filter.通过

SSH2——filter过滤器

概述: 过滤器是Servlet2.3以上新增加的一个功能,其技术也是非常强大的.通过Filter技术可以对WEB服务器的文件进行拦截,从而实现一些特殊的功能.在JSP开发应用中也是必备的技能之一.Filter可以改变一个request(请求)和修改一个response(响应).Filter不是一个Servlet,它不能产生一个response,它能够在一个requsst到达Servlet之前预处理request,也可以在离开Servlet时处理response. 原理: 当Web容器接受到一个对