What are Angular Filters?
Angular filters help with the formatting of the value of an expression that is displayed to the user with no change to the original format. An example is if you want a string in lowercase or uppercase, which can be achieved using the AngularJS filters. Built-in filters like ‘lowercase’, and ‘uppercase’ are available, which can generate lowercase and uppercase output as necessary.
When to use a filter in Angular?
Angular filters are used when the data needs to be displayed in a particular format in the view part. Data can be displayed in lowercase format, uppercase format, and more. AngularJS filters can change the way the output is displayed.
Whatever text it is and in whichever format it is in, the text can be easily displayed in any format by AngularJS depending on the filter type that is used.
Check out our Angular tutorial and get started with Angular today!
Various Angular Filters
AngularJS Filters alter the data and it can be implemented to directives and expressions by a pipe character. Filters in AngularJS are –
- Lowercase
- Uppercase
- Currency
- Filter
- order by
- Date
- Number
1. lowercase
It is used to convert the text to lower case text. It formats strings into lower case.
e.g.
<!DOCTYPE html>
<html>
<img src="" data-wp-preserve="%3Cscript%20src%3D%20%22http%3A%2F%2Fajax.googleapis.com%2Fajax%2Flibs%2Fangularjs%2F1.3.14%2Fangular.min.js%22%3E%3C%2Fscript%3E" data-mce-resize="false" data-mce-placeholder="1" class="mce-object" width="20" height="20" alt="<script>" title="<script>" />
<body>
<div ng-app="" ng-init="Name='Intellipaat'">
<p>Name: {{ Name | lowercase }}</p>
</div>
</body>
</html>
Output
Name: intellipaat
2. uppercase
It is used to convert the text to the upper case text. It formats strings into upper case.
e.g.
<!DOCTYPE html>
<html>
<img src="" data-wp-preserve="%3Cscript%20src%3D%20%22http%3A%2F%2Fajax.googleapis.com%2Fajax%2Flibs%2Fangularjs%2F1.3.14%2Fangular.min.js%22%3E%3C%2Fscript%3E" data-mce-resize="false" data-mce-placeholder="1" class="mce-object" width="20" height="20" alt="<script>" title="<script>" />
<body>
<div ng-app="" ng-init="Name='Intellipaat'">
<p>Name: {{ Name | uppercase }}</p>
</div>
</body>
</html>
Output
Name: INTELLIPAAT
3. currency
It formats a number into a currency format.
e.g.
<!DOCTYPE html>
<html>
<img src="" data-wp-preserve="%3Cscript%20src%3D%20%22http%3A%2F%2Fajax.googleapis.com%2Fajax%2Flibs%2Fangularjs%2F1.3.14%2Fangular.min.js%22%3E%3C%2Fscript%3E" data-mce-resize="false" data-mce-placeholder="1" class="mce-object" width="20" height="20" alt="<script>" title="<script>" />
<body>
<div ng-app="" >
Salary: <input type="number" ng-model="salary">
<p>Total = {{salary | currency }}</p>
</div>
</body>
</html>
Output
Salary: 100
Total = $100.00
Watch this Full Stack Web Development Course video:
4. filter
It selects a subset of items from an array according to to the specified condition.
e.g.
<html>
<head>
<img src="" data-wp-preserve="%3Cscript%20src%20%3D%20%22http%3A%2F%2Fajax.googleapis.com%2Fajax%2Flibs%2Fangularjs%2F1.3.14%2Fangular.min.js%22%3E%3C%2Fscript%3E" data-mce-resize="false" data-mce-placeholder="1" class="mce-object" width="20" height="20" alt="<script>" title="<script>" />
</head>
<body>
<div ng-app = "details" ng-controller = "studentController">
Enter subject: <input type = "text" ng-model = "subjectName">
<ul>
<li ng-repeat = "subject in student.subjects | filter: subjectName ">
{{ subject.name + ', marks:' + subject.marks }}
</li>
</ul>
</div>
<img src="" data-wp-preserve="%3Cscript%3E%0Avar%20details%3D%20angular.module(%22details%22%2C%20%5B%5D)%3B%0Adetails.controller('studentController'%2C%20function(%24scope)%20%7B%0A%24scope.student%20%3D%20%7B%0Asubjects%3A%5B%0A%7Bname%3A'English'%2Cmarks%3A85%7D%2C%0A%7Bname%3A'Math'%2Cmarks%3A90%7D%2C%0A%7Bname%3A'Physics'%2Cmarks%3A80%7D%2C%0A%7Bname%3A'Chemistry'%2Cmarks%3A75%7D%0A%5D%0A%7D%3B%0A%7D)%3B%0A%3C%2Fscript%3E" data-mce-resize="false" data-mce-placeholder="1" class="mce-object" width="20" height="20" alt="<script>" title="<script>" />
</body>
</html>
Output
5. orderBy
It orders an array according to the specified condition. You can use orderBy as follows in the above application:
e.g.
<li ng-repeat = "subject in student.subjects | filter: subjectName |orderBy:'marks'">
{{ subject.name + ', marks:' + subject.marks }}
</li>
Output
If you are an AngularJS enthusiast, enroll in the Angular Certification Course and get certified now!
6. Date
The date filter in AngularJS can be used to convert the date into a string as per the specified date format.
Syntax:
{{date_expression | date : 'format'}}
The various formats are YYYY, MM ,DD, D etc.
Example:
<!DOCTYPE html>
<html >
<head>
<img src="" data-wp-preserve="%3Cscript%20src%3D%22https%3A%2F%2Fajax.googleapis.com%2Fajax%2Flibs%2Fangularjs%2F1.8.2%2Fangular.min.js%22%3E%3C%2Fscript%3E" data-mce-resize="false" data-mce-placeholder="1" class="mce-object" width="20" height="20" alt="<script>" title="<script>" />
<img src="" data-wp-preserve="%3Cscript%20src%3D%22~%2FScripts%2Fangular.js%22%3E%3C%2Fscript%3E" data-mce-resize="false" data-mce-placeholder="1" class="mce-object" width="20" height="20" alt="<script>" title="<script>" />
</head>
<body ng-app>
<div ng-init="Date = 0867610000000 "> <!--423234234888-->
Default date: {{Date| date}} <br />
Year: {{Date | date:'yyyy'}} <br />
</div>
</body>
</html>
Output:
Default date: June 30, 1997
Year: 1997
Get 100% Hike!
Master Most in Demand Skills Now!
7. Number
The number filter can be used to format any data or numerical value taken as an input. It can add a comma or convert to the specified fraction size. In the case of invalid numeric data in the number expression, the number filter will display an empty string.
Syntax:
{{ number_expression | number:fractionSize}}
Example:
<!DOCTYPE html>
<html>
<head>
<img src="" data-wp-preserve="%3Cscript%20src%3D%22https%3A%2F%2Fajax.googleapis.com%2Fajax%2Flibs%2Fangularjs%2F1.8.2%2Fangular.min.js%22%3E%3C%2Fscript%3E" data-mce-resize="false" data-mce-placeholder="1" class="mce-object" width="20" height="20" alt="<script>" title="<script>" />
</head>
<body ng-app >
<h1>AngularJS Number Filter Demo: </h1>
Enter Book Name:<br /> <input type="name" /> <br />
Enter Price: <br /> <input type="number" ng-model="Price" /> <br /><br />
100 | number = {{100 | number}} <br />
Book Price | number = {{Price | number}} <br />
Book Price | number:2 = {{Price | number:2}} <br />
Book Price | number = <span ng-bind="Price | number"></span>
</body>
</html>
Output:
AngularJS Number Filter Demo:
Enter Price:
100 | number =
Price | number =
Price | number:3 =
Price | number =
When a value is entered in the text field, then the output will show as:
AngularJS Number Filter Demo:
Enter Price: 123
100 | number = 100
Book Price | number = 123
Book Price | number:2 = 123.00
Book Price | number = 123
Custom Filters in AngularJS
Let’s now discuss the customized filters that AngularJSa allows to create. A custom filter can be created by registering a filter factory function in a module. The AngularJS filter function should be a pure function, meaning it should produce the same result as per the given input, and it should not have any effect on an external state.
Example:
<!doctype html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Example - example-filter-reverse-production</title>
<img src="" data-wp-preserve="%3Cscript%20src%3D%22%2F%2Fcode.angularjs.org%2F1.7.7%2Fangular.min.js%22%3E%20%0A%20%20%3C%2Fscript%3E" data-mce-resize="false" data-mce-placeholder="1" class="mce-object" width="20" height="20" alt="<script>" title="<script>" />
<img src="" data-wp-preserve="%3Cscript%20src%3D%22script.js%22%3E%3C%2Fscript%3E" data-mce-resize="false" data-mce-placeholder="1" class="mce-object" width="20" height="20" alt="<script>" title="<script>" />
<img src="" data-wp-preserve="%3Cscript%20src%3D%22https%3A%2F%2Fajax.googleapis.com%2Fajax%2Flibs%2Fangularjs%2F1.8.2%2Fangular.min.js%22%3E%3C%2Fscript%3E" data-mce-resize="false" data-mce-placeholder="1" class="mce-object" width="20" height="20" alt="<script>" title="<script>" />
</head>
<body ng-app="ReverseFilter">
<div ng-controller="ReverseController">
<input ng-model="msg" type="text"><br>
Without Filter Content: {{msg}}<br>
Reverse Filter Content: {{msg|reverse}}<br>
Uppercase Filter on Reverse Filter: {{msg|reverse:true}}<br>
</div>
</body>
<img src="" data-wp-preserve="%3Cscript%3E%0A(function(angular)%20%7B%0A%20%20'use%20strict'%3B%0Aangular.module('ReverseFilter'%2C%20%5B%5D)%0A%20%20.filter('reverse'%2C%20function()%20%7B%0A%20%20return%20function(input%2C%20uppercase)%20%7B%0A%20%20input%20%3D%20input%20%7C%7C%20''%3B%0A%20%20var%20out%20%3D%20''%3B%0A%20%20for%20(var%20x%20%3D%200%3B%20x%20%3C%20input.length%3B%20x%2B%2B)%20%7B%0A%20%20%20out%20%3D%20input.charAt(x)%20%2B%20out%3B%0A%20%20%20%7D%0A%0A%20%20%20%2F%2F%20conditional%20applying%20on%20reversed%20string%20to%20make%20uppercase%0A%20%20%20if%20(uppercase)%20%7B%0A%20%20%20%20%20out%20%3D%20out.toUpperCase()%3B%0A%20%20%20%20%7D%0A%20%20%20%20return%20out%3B%0A%20%20%7D%3B%0A%7D)%0A%20%20%20%20.controller('ReverseController'%2C%20%5B'%24scope'%2C%20'reverseFilter'%2C%20function(%24scope%2C%20reverseFilter)%20%7B%0A%20%20%24scope.msg%20%3D%20'intellipaat'%3B%0A%20%20%24scope.filteredMessage%20%3D%20reverseFilter(%24scope.msg)%3B%0A%20%7D%5D)%3B%0A%7D)(window.angular)%3B%0A%0A%3C%2Fscript%3E" data-mce-resize="false" data-mce-placeholder="1" class="mce-object" width="20" height="20" alt="<script>" title="<script>" />
</html>
Output:
intellipaat
Without Filter Content: intellipaat
Reverse Filter Content: taapilletni
Uppercase Filter on Reverse Filter: TAAPILLETNI
Testing of Custom Filters
Filtered code can be tested like any other code. beforeEach (module(‘core’)) loads the core module into the injector. Core module contains the checkmark filter.
describe('UserName', function () {
var $controller, UpperCase;
beforeEach(module('core'));
beforeEach(inject(function ($filter) {
UpperCase = $filter('UpperCase');
}));
});
Conclusion
In conclusion, AngularJS filters are built-in services in Angular that can be used to format the data. The data is gathered as input from users and displayed to them in a filtered manner in the view part. There are different AngularJS filters available used for filtering data.
Preparing for a Job interview? Check out our Top Angular Interview Questions!