首页 > 语言 > JavaScript > 正文

AngularJS基础知识笔记之过滤器

2024-05-06 16:19:48
字体:
来源:转载
供稿:网友

在我们开发中经常需要在页面显示给用户的信息需要一定处理格式化,才能显示给用户。比如时间本地化,或者yyyy-MM-dd HH:mm:ss格式,数字精度格式化,本地化,人名格式化等等。在angularjs中为我们提供了叫filter的指令,让我们能够很轻易就能做到着一些列的功能

过滤器是用来更改修改数据,并且可以在表达式或使用管道符指令将其归入。以下是常用的过滤器的列表。

S.No.名称描述

1大写转换文本为大写文本。

2小写转换文本为小写文本。

3货币货币格式格式文本。

4过滤器过滤数组中它根据所提供的标准的一个子集。

5排序排序提供标准的基础数组。 大写过滤器

添加大写的过滤器使用管道符的表达式。在这里,添加了大写过滤器,全部用大写字母打印学生姓名。

 

 
  1. Enter first name:<input type="text" ng-model="student.firstName"
  2. Enter last name: <input type="text" ng-model="student.lastName"
  3. Name in Upper Case: {{student.fullName() | uppercase}} 

小写过滤器

添加小写的过滤器,使用管道符的表达式。在这里添加小写过滤器,以小写字母打印学生姓名。

 

 
  1. Enter first name:<input type="text" ng-model="student.firstName"
  2. Enter last name: <input type="text" ng-model="student.lastName"
  3. Name in Upper Case: {{student.fullName() | lowercase}} 

货币滤波器

加币过滤器使用管道符返回数的表达式。在这里,我们添加了过滤器,货币使用货币格式的打印费用。

 

 
  1. Enter fees: <input type="text" ng-model="student.fees"
  2. fees: {{student.fees | currency}} 

过滤器的过滤器

要仅显示所需的主题,我们使用subjectName作为过滤器。

 

 
  1. Enter subject: <input type="text" ng-model="subjectName"
  2. Subject: 
  3. <ul> 
  4. <li ng-repeat="subject in student.subjects | filter: subjectName"
  5. {{ subject.name + ', marks:' + subject.marks }} 
  6. </li> 
  7. </ul> 

排序过滤器

要通过标记排序主题,我们使用orderBy标记。

Subject:

 

 
  1. <ul> 
  2. <li ng-repeat="subject in student.subjects | orderBy:'marks'"
  3. {{ subject.name + ', marks:' + subject.marks }} 
  4. </li> 
  5. </ul> 

例子

下面的例子将展示上述所有的过滤器。

testAngularJS.html

 

 
  1. <html> 
  2. <head> 
  3. <title>Angular JS Filters</title> 
  4. </head> 
  5. <body> 
  6. <h2>AngularJS Sample Application</h2> 
  7. <div ng-app="" ng-controller="studentController"
  8. <table border="0"
  9. <tr><td>Enter first name:</td><td><input type="text" ng-model="student.firstName"></td></tr> 
  10. <tr><td>Enter last name: </td><td><input type="text" ng-model="student.lastName"></td></tr> 
  11. <tr><td>Enter fees: </td><td><input type="text" ng-model="student.fees"></td></tr> 
  12. <tr><td>Enter subject: </td><td><input type="text" ng-model="subjectName"></td></tr> 
  13. </table> 
  14. <br/> 
  15. <table border="0"
  16. <tr><td>Name in Upper Case: </td><td>{{student.fullName() | uppercase}}</td></tr> 
  17. <tr><td>Name in Lower Case: </td><td>{{student.fullName() | lowercase}}</td></tr> 
  18. <tr><td>fees: </td><td>{{student.fees | currency}}</td></tr> 
  19. <tr><td>Subject:</td><td> 
  20. <ul> 
  21. <li ng-repeat="subject in student.subjects | filter: subjectName |orderBy:'marks'"
  22. {{ subject.name + ', marks:' + subject.marks }} 
  23. </li> 
  24. </ul> 
  25. </td></tr> 
  26. </table> 
  27. </div> 
  28. <script> 
  29. function studentController($scope) { 
  30. $scope.student = { 
  31. firstName: "Mahesh"
  32. lastName: "Parashar"
  33. fees:500, 
  34. subjects:[ 
  35. {name:'Physics',marks:70}, 
  36. {name:'Chemistry',marks:80}, 
  37. {name:'Math',marks:65} 
  38. ], 
  39. fullName: function() { 
  40. var studentObject; 
  41. studentObject = $scope.student; 
  42. return studentObject.firstName + " " + studentObject.lastName; 
  43. }; 
  44. </script> 
  45. <script src="http://ajax.googleapis.com/ajax/libs/angularjs/1.2.15/angular.min.js"></script> 
  46. </body> 
  47. </html> 

以上所述就是本文的全部内容了,希望大家能够喜欢。

发表评论 共有条评论
用户名: 密码:
验证码: 匿名发表

图片精选