ホームページ  >  記事  >  ウェブフロントエンド  >  AngularJS_AngularJS でのフィルターの使用の詳細な説明

AngularJS_AngularJS でのフィルターの使用の詳細な説明

WBOY
WBOYオリジナル
2016-05-16 15:54:381118ブラウズ

フィルターはデータを変更するために使用され、式に含めたり、パイプ ディレクティブを使用したりできます。以下は一般的に使用されるフィルターのリストです。

2015616121340418.jpg (540×292)

小文字フィルター

パイプ式を使用して小文字フィルターを追加します。生徒の名前を小文字で印刷するには、ここに小文字フィルターを追加します。

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

通貨フィルター

カナダドルフィルターはパイプ文字を使用して数値式を返します。ここでは、通貨形式を使用して料金を出力するために、フィルタ「通貨」を追加しました。

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

フィルターのフィルター

必要な件名のみを表示するには、subjectName をフィルターとして使用します。

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

並べ替えフィルター

タグでトピックを並べ替えるには、orderBy タグを使用します。

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

次の例は、上記のすべてのフィルターを示します。
testAngularJS.html

<html>
<head>
<title>Angular JS Filters</title>
</head>
<body>
<h2>AngularJS Sample Application</h2>
<div ng-app="" ng-controller="studentController">
<table border="0">
<tr><td>Enter first name:</td><td><input type="text" ng-model="student.firstName"></td></tr>
<tr><td>Enter last name: </td><td><input type="text" ng-model="student.lastName"></td></tr>
<tr><td>Enter fees: </td><td><input type="text" ng-model="student.fees"></td></tr>
<tr><td>Enter subject: </td><td><input type="text" ng-model="subjectName"></td></tr>
</table>
<br/>
<table border="0">
<tr><td>Name in Upper Case: </td><td>{{student.fullName() | uppercase}}</td></tr>
<tr><td>Name in Lower Case: </td><td>{{student.fullName() | lowercase}}</td></tr>
<tr><td>fees: </td><td>{{student.fees | currency}}</td></tr>
<tr><td>Subject:</td><td>
<ul>
  <li ng-repeat="subject in student.subjects | filter: subjectName |orderBy:'marks'">
   {{ subject.name + ', marks:' + subject.marks }}
  </li>
</ul>
</td></tr>
</table>
</div>
<script>
function studentController($scope) {
  $scope.student = {
   firstName: "Mahesh",
   lastName: "Parashar",
   fees:500,
   subjects:[
     {name:'Physics',marks:70},
     {name:'Chemistry',marks:80},
     {name:'Math',marks:65}
   ],
   fullName: function() {
     var studentObject;
     studentObject = $scope.student;
     return studentObject.firstName + " " + studentObject.lastName;
   }
  };
}
</script>
<script src="http://ajax.googleapis.com/ajax/libs/angularjs/1.2.15/angular.min.js"></script>
</body>
</html>

出力

Web ブラウザで textAngularJS.html を開くと、次の結果が表示されます:

2015616121404523.png (688×433)

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。