Angular 2에서 입력 이벤트 관리
AngularJS에서 개발자는 ng-model-options 지시문을 활용하여 입력 모델 업데이트를 디바운스할 수 있습니다. Angular 2에서는 RxJS 연산자를 사용하여 비슷한 기능을 사용할 수 있습니다.
RxJS로 디바운싱
Angular 2에서 모델을 디바운스하려면 debounceTime()을 활용하세요. 양식 컨트롤의 valueChanges에 대한 연산자가 관찰 가능합니다. 이 연산자는 마지막 이벤트 이후 지정된 시간이 경과할 때까지 후속 값 방출을 지연합니다.
<br>import { debounceTime } from 'rxjs/operators';</p> <p>formCtrlSub = this. firstNameControl.valueChanges</p> <pre class="brush:php;toolbar:false">.pipe( debounceTime(1000) ) .subscribe(newValue => this.firstName = newValue);
이벤트 제한
또한 이벤트 크기 조정과 같은 이벤트를 제한하여 과도한 업데이트. throttleTime() 연산자는 지정된 시간 창 내에서 하나의 값만 방출되도록 보장합니다.
<br>import { throttleTime } from 'rxjs/operators';</p> <p>resizeSub = Observable.fromEvent(window, 'resize')</p> <pre class="brush:php;toolbar:false">.pipe( throttleTime(200) ) .subscribe(e => { console.log('resize event', e); this.firstName += '*'; // change something to show it worked });
효율적인 이벤트 처리
위의 접근 방식은 변경을 트리거합니다. 디바운싱되거나 제한되는 경우에도 모든 이벤트에 대한 탐지가 가능합니다. 보다 효율적인 이벤트 처리를 위해 Angular 영역 외부에 RxJS Observable을 생성하고 구독 콜백 메서드에서 변경 감지를 수동으로 트리거하는 것을 고려하세요.
<br>ngAfterViewInit() {</p> <pre class="brush:php;toolbar:false">this.ngZone.runOutsideAngular(() => { this.keyupSub = Observable.fromEvent(this.inputElRef.nativeElement, 'keyup') ... this.resizeSub = Observable.fromEvent(window, 'resize') ... });
}
RxJS 연산자와 사전 변경 감지 트리거를 활용하면 Angular 2에서 입력 이벤트를 효과적으로 관리하여 원활하고 반응이 빠른 사용자 상호 작용을 보장할 수 있습니다.
위 내용은 RxJS를 사용하여 Angular 2에서 입력 이벤트를 효과적으로 관리하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!