Angular 2-맞춤형 파이프

Angular 2에는 사용자 지정 파이프를 만드는 기능도 있습니다. 사용자 지정 파이프를 정의하는 일반적인 방법은 다음과 같습니다.

import { Pipe, PipeTransform } from '@angular/core';  
@Pipe({name: 'Pipename'}) 

export class Pipeclass implements PipeTransform { 
   transform(parameters): returntype { } 
}

어디,

  • 'Pipename' − 이것은 파이프의 이름입니다.

  • Pipeclass − 이것은 사용자 정의 파이프에 할당 된 클래스의 이름입니다.

  • Transform − 배관 작업을하는 기능입니다.

  • Parameters − 파이프로 전달되는 매개 변수입니다.

  • Returntype − 이것은 파이프의 반환 유형입니다.

2 개의 숫자를 곱하는 사용자 지정 파이프를 만들어 보겠습니다. 그런 다음 컴포넌트 클래스에서 해당 파이프를 사용합니다.

Step 1 − 먼저 multiplier.pipe.ts라는 파일을 생성합니다.

Step 2 − 위에서 생성 된 파일에 다음 코드를 삽입합니다.

import { 
   Pipe, 
   PipeTransform 
} from '@angular/core';  

@Pipe ({ 
   name: 'Multiplier' 
}) 

export class MultiplierPipe implements PipeTransform { 
   transform(value: number, multiply: string): number { 
      let mul = parseFloat(multiply); 
      return mul * value 
   } 
}

위 코드에 대해 다음 사항에 유의해야합니다.

  • 먼저 Pipe 및 PipeTransform 모듈을 가져옵니다.

  • 그런 다음 'Multiplier'라는 이름으로 파이프를 생성합니다.

  • PipeTransform 모듈을 구현하는 MultiplierPipe라는 클래스를 만듭니다.

  • 그런 다음 변환 함수는 값과 여러 매개 변수를 받아 두 숫자의 곱셈을 출력합니다.

Step 3 − app.component.ts 파일에 다음 코드를 추가하십시오.

import { 
   Component 
} from '@angular/core';  

@Component ({ 
   selector: 'my-app', 
   template: '<p>Multiplier: {{2 | Multiplier: 10}}</p>' 
}) 
export class AppComponent {  }

Note − 템플릿에서는 새로운 맞춤형 파이프를 사용합니다.

Step 4 − app.module.ts 파일에 다음 코드가 있는지 확인하십시오.

import {
   NgModule
} from '@angular/core';

import {
   BrowserModule
} from '@angular/platform-browser';

import {
   AppComponent
} from './app.component';

import {
   MultiplierPipe
} from './multiplier.pipe'

@NgModule ({
   imports: [BrowserModule],
   declarations: [AppComponent, MultiplierPipe],
   bootstrap: [AppComponent]
})

export class AppModule {}

위 코드에 대해 다음 사항에 유의해야합니다.

  • MultiplierPipe 모듈을 포함해야합니다.

  • 또한 선언 섹션에 포함되어 있는지 확인해야합니다.

모든 코드 변경 사항을 저장하고 브라우저를 새로 고치면 다음 출력이 표시됩니다.