NativeScript-이벤트 처리
모든 GUI 애플리케이션에서 이벤트는 사용자 상호 작용을 가능하게하는 매우 중요한 역할을합니다. 사용자가 애플리케이션과 상호 작용할 때마다 이벤트가 발생하고 해당 작업이 실행됩니다.
예를 들어 사용자가 응용 프로그램의 로그인 페이지에서 로그인 버튼을 클릭하면 로그인 프로세스가 트리거됩니다.
이벤트에는 두 명의 배우가 참여합니다.
Event sender − 실제 이벤트를 발생시키는 객체.
Event listener − 특정 이벤트를 수신 한 다음 이벤트가 발생하면 실행되는 함수.
관찰 가능한 클래스
이벤트를 처리하기 위해 미리 정의 된 클래스입니다. 아래에 정의되어 있습니다-
const Observable = require("tns-core-modules/data/observable").Observable;
NativeScript에서 거의 모든 객체는 Observable 클래스에서 파생되므로 모든 객체는 이벤트를 지원합니다.
이벤트 리스너
이 장에서는 객체를 생성하고 객체에 이벤트 리스너를 추가하는 방법을 이해하겠습니다.
1 단계
아래 지정된대로 이벤트를 생성하는 데 사용되는 버튼을 만듭니다.
const Button = require("tns-core-modules/ui/button").Button;
const testButton = new Button();
2 단계
다음으로 아래 지정된대로 버튼에 텍스트를 추가합니다.
testButton.text = "Click";
3 단계
아래에 지정된대로 onTap 함수를 만듭니다.
let onTap = function(args) {
console.log("you clicked!");
};
4 단계
이제 아래 지정된대로 onTap 함수에 탭 이벤트를 연결합니다.
testButton.on("tap", onTap, this);
이벤트 리스너를 추가하는 다른 방법은 다음과 같습니다.
testButton.addEventListener("tap", onTap, this);
5 단계
이벤트를 첨부하는 다른 방법은 아래 지정된대로 UI 자체를 사용하는 것입니다.
<Button text="click" (tap)="onTap($event)"></Button>
여기,
$ event는 EventData 유형입니다. EventData에는 두 개의 속성이 포함되어 있으며 다음과 같습니다.
Object− 이벤트를 발생시키는 데 사용되는 Observable 인스턴스. 이 시나리오에서는 Button 개체입니다.
EventName− 이벤트 이름입니다. 이 시나리오에서는 탭 이벤트입니다.
6 단계
마지막으로 이벤트 리스너는 아래에 지정된대로 언제든지 분리 / 제거 할 수 있습니다.
testButton.off(Button.onTap);
아래와 같이 다른 형식을 사용할 수도 있습니다.
testButton.removeEventListener(Button.onTap);
BlankNgApp 수정
NativeScript의 이벤트를 더 잘 이해하기 위해 BlankNgApp 애플리케이션을 수정 해 보겠습니다.
1 단계
홈 구성 요소의 UI를 열고 src/app/home/home.component.html 코드 아래에 추가하십시오-
<ActionBar>
<Label text="Home"></Label>
</ActionBar>
<StackLayout>
<Button text='Fire an event' class="-primary" color='gray' (tap)='onButtonTap($event)'></Button>
</StackLayout>
여기,
탭은 이벤트이고 버튼은 이벤트 발생기입니다.
onButtonTap은 이벤트 리스너입니다.
2 단계
홈 컴포넌트의 코드를 열고 ‘src/app/home/home.component.ts’ 아래 코드를 업데이트하십시오-
import { Component, OnInit } from "@angular/core";
import { EventData } from "tns-core-modules/data/observable";
import { Button } from "tns-core-modules/ui/button"
@Component({
selector: "Home",
templateUrl: "./home.component.html"
})
export class HomeComponent implements OnInit {
constructor() {
// Use the component constructor to inject providers.
}
ngOnInit(): void {
// Init your component properties here.
}
onButtonTap(args: EventData): void {
console.log(args.eventName);
const button = <Button>args.object;
console.log(button.text);
}
}
여기,
새로운 이벤트 리스너 onButtonTap을 추가했습니다.
이벤트 이름, 탭 및 버튼 텍스트를 인쇄하고 콘솔에서 이벤트를 실행합니다.
3 단계
애플리케이션을 실행하고 버튼을 탭합니다. 콘솔에 아래 줄을 인쇄합니다.
LOG from device <device name>: tap
LOG from device <device name>: Fire an event