In Angular, we can write our own custom pipes to transform the input data as per our desired output. If you want to learn first about pipes, then you can check the journal entry “Understanding Angular Pipes”.
In this journal entry, we will be focusing on creating a custom pipe as per our requirements.
Below is the sample code, basic definition or the structure of creating a custom pipe.
import { | |
Pipe, | |
PipeTransform | |
} from '@angular/core'; | |
@Pipe({ | |
name: 'customPipe' | |
}) | |
export class NameofClass implements PipeTransform { | |
transform(value: string, args: string[]): any { | |
//Play with value and argument and return the result | |
return value; | |
} | |
} |
Points to remember while defining your custom pipe in Angular:
- The Pipe is a class that contains “pipe” metadata.
- The Pipe class contains method “transform”, which is implemented from “PipeTransform” interface. This method accepts the value and optionally accepts the arguments and converts it to the required format.
- We can add the required argument to the “transform” method.
- The @pipe decorator is used to declare Pipe and it is defined in core Angular library, so we need to import this library. This decorator allows us to define the name of Pipe, which is used in HTML markup.
- The “transform” method can return any type of value. If our Pipe’s return type is decided on run time, we can use “any,” otherwise, we can define specific types like number or string.
The PipeTransform interface
The
transform
method is essential to a pipe. ThePipeTransform
interface defines that method and guides both tooling and the compiler. Technically, it’s optional; Angular looks for and executes thetransform
method regardless.
EXAMPLE
Bold pipe example:
In the below-specified example, we have created a custom pipe which converts the text value to bold and returns that text as an output.
import { | |
Pipe, | |
PipeTransform | |
} from '@angular/core'; | |
@Pipe({ | |
name: 'bold' | |
}) | |
export class BoldPipe implements PipeTransform { | |
transform(value: string): any { | |
return '<b>' + value + '</b>'; | |
} | |
} |
import { | |
Component | |
} from '@angular/core'; | |
//import pipe(s) | |
import { | |
BoldPipe | |
} from './textboldpipe'; | |
@Component({ | |
selector: 'test-app', | |
pipes: [BoldPipe], | |
templateUrl: './app/example.html' | |
}) | |
export class AppComponent { | |
name = "developersjournal"; | |
myText = "This is my test string."; | |
} |
<div> | |
<h4>Bold Pipe example</h4> | |
Hello, My name is <span [outerHTML]="name | titlecase | bold"></span> | |
</div> |
Comments are closed.