NativeScript - Gestion des événements

Dans chaque application GUI, les événements jouent un rôle très important pour permettre l'interaction de l'utilisateur. Chaque fois que l'utilisateur interagit avec l'application, un événement se déclenche et une action correspondante est exécutée.

Par exemple, lorsque l'utilisateur clique sur le bouton Connexion dans la page de connexion d'une application, cela déclenche le processus de connexion.

Les événements impliquent deux acteurs -

  • Event sender - objet, qui soulève l'événement réel.

  • Event listener - fonction, qui écoute un événement particulier et est ensuite exécutée lorsqu'un événement est déclenché.

Classe observable

C'est une classe prédéfinie pour gérer les événements. Il est défini ci-dessous -

const Observable = require("tns-core-modules/data/observable").Observable;

Dans NativeScript, presque chaque objet dérive de la classe Observable et donc chaque objet prend en charge les événements.

Écouteur d'événements

Voyons comment créer un objet et ajouter un écouteur d'événement à l'objet dans ce chapitre.

Étape 1

Créez un bouton qui est utilisé pour générer un événement comme spécifié ci-dessous -

const Button = require("tns-core-modules/ui/button").Button; 
const testButton = new Button();

Étape 2

Ensuite, ajoutez du texte au bouton comme spécifié ci-dessous -

testButton.text = "Click";

Étape 3

Créez une fonction, onTap comme spécifié ci-dessous -

let onTap = function(args) {
   console.log("you clicked!"); 
};

Étape 4

Maintenant, attachez l'événement tap à la fonction onTap comme spécifié ci-dessous -

testButton.on("tap", onTap, this);

Une autre façon d'ajouter un écouteur d'événement est la suivante -

testButton.addEventListener("tap", onTap, this);

Étape 5

Une autre façon d'attacher un événement consiste à utiliser l'interface utilisateur elle-même, comme spécifié ci-dessous -

<Button text="click" (tap)="onTap($event)"></Button>

Ici,

$ event est de type EventData. EventData contient deux propriétés et elles sont les suivantes -

Object- Instance observable utilisée pour déclencher un événement. Dans ce scénario, il s'agit d'un objet Button.

EventName- C'est le nom de l'événement. Dans ce scénario, il s'agit d'un événement tap.

Étape 6

Enfin, un écouteur d'événement peut être détaché / supprimé à tout moment comme spécifié ci-dessous -

testButton.off(Button.onTap);

Vous pouvez également utiliser un autre format comme indiqué ci-dessous -

testButton.removeEventListener(Button.onTap);

Modification de BlankNgApp

Modifions l'application BlankNgApp pour mieux comprendre les événements dans NativeScript.

Étape 1

Ouvrez l'interface utilisateur du composant d'accueil, src/app/home/home.component.html et ajoutez ci-dessous le code -

<ActionBar> 
   <Label text="Home"></Label> 
</ActionBar>
<StackLayout> 
   <Button text='Fire an event' class="-primary" color='gray' (tap)='onButtonTap($event)'></Button>
</StackLayout>

Ici,

  • tap est l'événement et Button est le déclencheur d'événement.

  • onButtonTap est l'écouteur d'événements.

Étape 2

Ouvrez le code du composant domestique, ‘src/app/home/home.component.ts’ et mettez à jour le code ci-dessous -

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); 
   } 
}

Ici,

  • Ajout d'un nouvel écouteur d'événement, onButtonTap.

  • Imprimez le nom de l'événement, appuyez sur et le texte du bouton, déclenchez un événement dans la console.

Étape 3

Exécutez l'application et appuyez sur le bouton. Il imprime la ligne ci-dessous dans la console.

LOG from device <device name>: tap 
LOG from device <device name>: Fire an event