NativeScript - Guide rapide

En règle générale, le développement d'une application mobile est une tâche complexe et difficile. Il existe de nombreux frameworks disponibles pour développer une application mobile. Android fournit un framework natif basé sur le langage Java et iOS fournit un framework natif basé sur le langage Objective-C / Shift. Cependant, pour développer une application prenant en charge les deux systèmes d'exploitation, nous devons coder dans deux langues différentes en utilisant deux frameworks différents.

Pour surmonter cette complexité, les frameworks mobiles prennent en charge cette fonctionnalité. La principale raison derrière l'utilisation d'un framework multiplateforme ou hybride est plus facile de maintenir une base de code unique. Certains des frameworks populaires sont NativeScript, Apache Cordova, Xamarin, etc.

Présentation des frameworks JavaScript

JavaScript est un langage multi-paradigme. Il prend en charge la programmation fonctionnelle, la programmation orientée objet et basée sur des prototypes. JavaScript a été initialement utilisé pour le côté client. De nos jours, JavaScript est également utilisé comme langage de programmation côté serveur. Les frameworks JavaScript sont un type d'outil qui rend l'utilisation de JavaScript plus facile et plus fluide.

En utilisant ce framework, les programmeurs peuvent facilement coder l'application en tant que périphérique responsive. La réactivité est l'une des raisons pour lesquelles ce cadre devient très populaire.

Jetons un coup d'œil à certains des frameworks JS populaires -

Angulaire

Angular est l'un des frameworks JavaScript les plus puissants, efficaces et open source. Nous pouvons créer des applications mobiles et de bureau. Google utilise ce cadre. Il est utilisé pour développer une application à page unique (SPA).

Vue.js

VueJS est un framework JavaScript progressif utilisé pour développer des interfaces Web interactives. C'est l'un des fameux frameworks utilisés pour simplifier le développement web. Il peut être facilement intégré dans de grands projets pour le développement front-end sans aucun problème. C'est le mode double intégration qui est l'une des fonctionnalités les plus attrayantes pour la création de SPA haut de gamme ou d'une application à page unique.

Réagir

ReactJS est une bibliothèque JavaScript utilisée pour créer des composants d'interface utilisateur réutilisables. Il est développé par Facebook. C'est actuellement l'une des bibliothèques JavaScript les plus populaires et elle a une base solide et une grande communauté derrière elle.

Node.js

Node.js est un environnement d'exécution open source multiplateforme pour le développement d'applications côté serveur et réseau. Il est construit sur le moteur JavaScript de Google Chrome (moteur V8). Les applications Node.js sont écrites en JavaScript et peuvent être exécutées sur OS X, Microsoft Windows et Linux. Il fournit une riche bibliothèque de divers modules JavaScript qui simplifie le développement d'applications Web.

Présentation de NativeScript

NativeScript est un framework open source utilisé pour créer des applications mobiles natives iOS et Android. C'est un framework compilé JIT. Le code NativeScript s'exécute sur la machine virtuelle JS. Il utilise le moteur d'exécution V8 pour les plates-formes Android et iOS. NativeScript utilise XML, JS et CSS pour le développement. Il a un WebIDE connu sous le nom de PlayGround. Ce PlayGround prend en charge une interface de travail facile, des projets faciles à gérer, un rechargement à chaud et un débogage sur les appareils.

NativeScript permet aux développeurs de créer rapidement et efficacement des applications natives multiplateformes et d'économiser sur les coûts de développement, de test et de formation. Par conséquent, les applications natives continueront d'être riches et solides pendant des années pour être meilleures et plus faciles à utiliser.

traits

NativeScript bénéficie d'un support communautaire dynamique. Certaines des principales fonctionnalités de NativeScript répertoriées ci-dessous -

  • Extensible

  • Remplacement du module à chaud

  • Facile à installer

  • Nous pouvons créer des animations, des graphiques, des graphiques et des listes riches

  • Les développeurs peuvent utiliser n'importe quelle vue comme racine d'une application

  • Codage paresseux

Avantages

NativeScript aide les petites ou grandes entreprises à créer des applications mobiles multiplateformes. Certains des principaux avantages sont:

  • Les développeurs peuvent réutiliser les outils et le code existants

  • Facile à modifier, dépanner et mettre à jour les nouvelles versions

  • L'expérience de développement est bonne, nous n'avons donc pas besoin de passer du temps pour apprendre de nouveaux outils

  • API spécifiques à la plate-forme à partir de JavaScript, éliminant le besoin d'apprendre les plugins Cordova

  • Authentification simplifiée avec différents fournisseurs de connexion

Cette section explique comment installer NativeScript sur votre machine.

Conditions préalables

Avant de passer à l'installation, nous avons besoin des prérequis suivants -

  • Node.js

  • Android

  • iOS

Vérifiez Node.js

Node.js est un moteur d'exécution JavaScript basé sur le moteur JavaScript interne de Google Chrome, v8. NativeScript utilise largement Node.js à des fins diverses telles que la création de l'application de modèle de démarrage, la compilation de l'application, etc. Il est obligatoire d'avoir Node.js sur votre machine.

J'espère que vous avez installé Node.js sur votre machine. S'il n'est pas installé, visitez le lien,https://nodejs.org/ et téléchargez le dernier package LTS et installez-le.

Pour vérifier si Node.js est correctement installé, tapez la commande ci-dessous sur votre terminal -

node --version

Vous pouvez voir la version. À partir de maintenant, la version stable actuelle «LTS» de node est la 12.14.0.

Configuration CLI

NativeScript CLI est une application basée sur un terminal / ligne de commande et vous permet de créer et de développer une application NativeScript. Le gestionnaire de packages Node.js npm est utilisé pour installer l'interface de ligne de commande NativeScript sur votre ordinateur.

Utilisez la commande ci-dessous pour installer la CLI NativeScript -

npm install -g nativescript

Après avoir exécuté cette commande, nous pourrions voir la sortie suivante -

setupcli

Nous avons installé la dernière CLI NativeScript, tns dans notre système. Maintenant, tapez la commande ci-dessous dans votre terminal -

tns

Cela listera le guide de démarrage rapide. Vous pouvez voir la sortie suivante -

cli

Nous pouvons utiliser tns pour créer et développer des applications même sans configuration supplémentaire. Mais nous n'avons pas pu déployer l'application sur un appareil réel. Au lieu de cela, nous pouvons exécuter l'application à l'aide de l'application NativeScript PlayGround iOS / Android. Nous le vérifierons dans les prochains chapitres.

Installation de l'application NativeScript Playground

Accédez à votre boutique d'applications iOS ou à Google Play Store et recherchez l'application NativeScript Playground. Une fois l'application répertoriée dans le résultat de la recherche, cliquez sur l'option d'installation. Il installera l' application NativeScript Playground sur notre appareil.

L' application NativeScript Playground sera utile pour tester vos applications sur un appareil Android ou iOS sans déployer l'application dans l'appareil réel ou l'émulateur. Cela réduira le temps de développement de l'application et un moyen facile de démarrer le développement de notre application mobile.

Configuration Android et iOS

Dans ce chapitre, apprenons à configurer le système pour créer et exécuter des applications iOS et Android dans un émulateur ou sur un appareil réel.

Étape 1: Dépendance Windows

Exécutez la commande ci-dessous dans votre invite de commande Windows et exécutez en tant qu'administrateur -

@powershell -NoProfile -ExecutionPolicy Bypass -Command "iex 
((new-object net.webclient).DownloadString('https://www.nativescript.org/setup/win'))"

Après cette commande, les scripts en cours de téléchargement installent les dépendances et les configurent.

Étape 2: Dépendance macOS

Pour installer sous macOS, vous devez vous assurer que Xcode est installé ou non. Xcode est obligatoire pour NativeScript. Si Xcode n'est pas installé, visitez le lien suivanthttps://developer.apple.com/xcode/et télécharger; puis installez-le.

Exécutez maintenant la commande suivante dans votre terminal -

sudo ruby -e "$(curl -fsSL https://www.nativescript.org/setup/mac)"

Après avoir exécuté la commande ci-dessus, le script installera les dépendances pour le développement iOS et Android. Une fois que c'est fait, fermez et redémarrez votre terminal.

Étape 3: Dépendance Android

J'espère que vous avez configuré les prérequis suivants -

  • JDK 8 ou supérieur

  • SDK Android

  • Référentiel de support Android

  • Dépôt Google

  • Android SDK Build-tools 28.0.3 ou supérieur

  • Studio Android

Si les prérequis ci-dessus ne sont pas configurés, visitez le lien suivant https://developer.android.com/studio/installez-le et installez-le. Enfin, ajoutez JAVA_HOME et ANDROID_HOME dans vos variables d'environnement.

Étape 4: vérifier les dépendances

Maintenant, tout est fait. Vous pouvez vérifier la dépendance à l'aide de la commande ci-dessous -

tns doctor

Cela vérifiera toutes les dépendances et résumera le résultat comme ci-dessous -

√ Getting environment information 
No issues were detected. 
√ Your ANDROID_HOME environment variable is set and points to correct directory. 
√ Your adb from the Android SDK is correctly installed. 
√ The Android SDK is installed. 
√ A compatible Android SDK for compilation is found. 
√ Javac is installed and is configured properly. 
√ The Java Development Kit (JDK) is installed and is configured properly. 
√ Local builds for iOS can be executed only on a macOS system. 
   To build for iOS on a different operating system, you can use the
   NativeScript cloud infrastructure. 
√ Getting NativeScript components versions information... 
√ Component nativescript has 6.3.0 version and is up to date. 
√ Component tns-core-modules has 6.3.2 version and is up to date. 
√ Component tns-android has 6.3.1 version and is up to date. 
√ Component tns-ios has 6.3.0 version and is up to date.

Si vous rencontrez des problèmes, veuillez corriger les problèmes avant de procéder au développement de l'application.

NativeScript est un framework avancé pour créer une application mobile. Il cache la complexité de la création d'une application mobile et expose une API assez simple pour créer une application mobile hautement optimisée et avancée. NativeScript permet même aux développeurs débutants de créer facilement des applications mobiles sous Android et iOS.

Comprenons l'architecture du framework NativeScript dans ce chapitre.

introduction

Le concept de base du framework NativeScript est de permettre au développeur de créer une application mobile de style hybride. L'application hybride utilise l'API de navigateur spécifique à la plate-forme pour héberger une application Web dans une application mobile normale et fournit un accès système à l'application via l'API JavaScript.

NativeScript investit massivement dans JavaScript languagepour fournir un cadre efficace aux développeurs. DepuisJavaScriptest un standard de facto pour la programmation côté client (développement Web) et chaque développeur connaît bien le langage JavaScript, il aide les développeurs à entrer facilement dans le framework NativeScript. Au bas niveau, NativeScript expose l'API native via une collection de plugins JavaScript appelésNative plugins.

NativeScript repose sur les bases de plugins natifs et fournit de nombreux modules JavaScript de haut niveau et faciles à utiliser . Chaque module fait une fonctionnalité spécifique comme l'accès à une caméra, la conception d'un écran, etc. Tous ces modules peuvent être combinés de plusieurs manières pour concevoir une application mobile complexe.

Le diagramme ci-dessous montre la vue d'ensemble de haut niveau du framework NativeScript -

NativeScript Application - Le framework NativeScript permet aux développeurs d'utiliser une application de style angulaire ou une application de style Vue.

JavaScript Modules - Le framework NativeScript fournit un ensemble riche de modules JavaScript clairement catégorisés en modules d'interface utilisateur, modules d'application, modules de base, etc. Tous les modules sont accessibles par application à tout moment pour écrire n'importe quel niveau d'application complexe.

JavaScript plugins- Le framework NativeScript fournit une grande collection de plugins JavaScript pour accéder aux fonctionnalités liées à la plate-forme. Modules utilise les plugins JavaScript pour fournir des fonctionnalités spécifiques à la plate-forme.

Native plugins- Les plugins natifs sont écrits dans un langage spécifique à la plate-forme pour envelopper les fonctionnalités du système qui seront ensuite utilisées par le plugin JavaScript.

Platform API - API fournie par les fournisseurs de plate-forme.

En bref, l'application NativeScript est écrite et organisée à l'aide de modules. Les modules sont écrits en JavaScript pur et les modules accèdent aux fonctionnalités liées à la plate-forme (chaque fois que nécessaire) via des plugins et enfin, les plugins relient l'API de la plate-forme et l'API JavaScript.

Flux de travail d'une application NativeScript

Comme nous l'avons appris précédemment, l'application NativeScript est composée de modules. Chaque module permet une fonctionnalité spécifique. Les deux catégories importantes de modules pour amorcer une application NativeScript sont les suivantes:

  • Modules racine

  • Modules de page

Les modules racine et page peuvent être classés en tant que modules d'application. Le module d'application est le point d'entrée de l'application NativeScript. Il amorce une page, permet au développeur de créer l'interface utilisateur de la page et permet enfin l'exécution de la logique métier de la page. Un module d'application se compose de trois éléments ci-dessous -

  • Conception de l'interface utilisateur codée en XML (par exemple page.xml / page.component.html)

  • Styles codés en CSS (par exemple page.css / page.component.css)

  • Logique métier réelle du module en JavaScript (par exemple page.js / page.component.ts)

NativeScript fournit de nombreux composants d'interface utilisateur (sous Module d'interface utilisateur) pour concevoir la page d'application. Le composant d'interface utilisateur peut être représenté au format XML ou au format HTML dans une application basée sur Angular. Le module d'application utilise le composant d'interface utilisateur pour concevoir la page et stocker la conception dans un fichier XML distinct, page.xml / page.component.html . Le design peut être stylisé à l'aide de CSS standard.

Les modules d'application stockent le style de la conception dans un CSS distinct, page.css / page.component.css. La fonctionnalité de la page peut être réalisée à l'aide de JavaScript / TypeScript, qui a un accès complet à la conception ainsi qu'aux fonctionnalités de la plate-forme. Le module d'application utilise un fichier séparé, page.js / page.component.ts pour coder la fonctionnalité réelle de la page.

Modules racine

NativeScript gère l'interface utilisateur et l'interaction utilisateur via des conteneurs d'interface utilisateur. Chaque conteneur d'interface utilisateur doit avoir un module racine et à travers lequel le conteneur d'interface utilisateur gère l'interface utilisateur. L'application NativeScript a deux types de conteneurs d'interface utilisateur -

Application Container- Chaque application NativeScript doit avoir un conteneur d'application et il sera défini à l'aide de la méthode application.run (). Il initialise l'interface utilisateur de l'application.

Model View Container- NativeScript gère les boîtes de dialogue modales à l'aide du conteneur de vue de modèle. Une application NativeScript peut avoir n'importe quel nombre de conteneurs de vue de modèle.

Chaque module racine ne doit avoir qu'un seul composant d'interface utilisateur comme contenu. Le composant d'interface utilisateur peut à son tour avoir d'autres composants d'interface utilisateur comme enfants. NativeScript fournit de nombreux composants d'interface utilisateur tels que TabView, ScrollView, etc., avec une fonction enfant. Nous pouvons les utiliser comme composant d'interface utilisateur racine. Une exception est Frame , qui n'a pas d'option enfant mais peut être utilisé comme composant racine. Frame fournit des options pour charger des modules de page et des options pour accéder également à d'autres modules de page .

Modules de page

Dans NativeScript, chaque page est essentiellement un module de page . Le module Page est conçu à l'aide du riche ensemble de composants d'interface utilisateur fournis par NativeScript. Les modules de page sont chargés dans l'application via le composant Frame (en utilisant son attribut defaultPage ou en utilisant la méthode navigate ()), qui à son tour est chargé à l'aide de modules racine , qui sont à nouveau chargés à l'aide de application.run () au démarrage de l'application.

Le flux de travail de l'application peut être représenté comme dans le diagramme ci-dessous -

Le diagramme ci-dessus est expliqué en détail dans les étapes suivantes -

  • L'application NativeScript démarre et appelle la méthode application.run ().

  • application.run () charge un module racine .

  • Le module racine est conçu en utilisant l'un des composants de l'interface utilisateur comme spécifié ci-dessous -

    • Frame

    • TabView

    • SideDrawer

    • Toute vue de mise en page

  • Le composant Frame charge la page spécifiée (module Page) et est rendu. Les autres composants de l'interface utilisateur seront rendus comme spécifié dans le module racine . Un autre composant d'interface utilisateur a également la possibilité de charger des modules de page comme contenu principal.

Flux de travail de l'application NativeScript basée sur Angular

Comme nous l'avons appris précédemment, le framework NativeScript fournit plusieurs méthodologies pour répondre à différentes catégories de développeurs. Les méthodologies prises en charge par NativeScript sont les suivantes -

  • NativeScript Core - Concept de base ou de base de NativeScript Framework

  • Angular + NativeScript - Méthodologie basée sur angulaire

  • Vuejs + NativeScript - Méthodologie basée sur Vue.js

Apprenons comment le framework Angular est intégré au framework NativeScript.

Étape 1

NativeScript fournit un objet (platformNativeScriptDynamic) pour amorcer l'application Angular. platformNativeScriptDynamic a une méthode, bootstrapModule, qui est utilisée pour démarrer l'application.

La syntaxe pour amorcer l'application à l'aide du framework Angular est la suivante -

import { platformNativeScriptDynamic } from "nativescript-angular/platform"; 
import { AppModule } from "./app/app.module"; 
platformNativeScriptDynamic().bootstrapModule(AppModule);

Ici,

AppModule est notre module racine.

Étape 2

Une implémentation simple (sous le code spécifié) du module d'application.

import { NgModule } from "@angular/core"; 
import { NativeScriptModule } from "nativescript-angular/nativescript.module"; 
import { AppRoutingModule } from "./app-routing.module"; 
import { AppComponent } from "./app.component"; 
@NgModule(
   {
      bootstrap: [
         AppComponent
      ], imports: [
         NativeScriptModule,
         AppRoutingModule
      ], declarations: [
         AppComponent
      ]
   }
) export class AppModule { }

Ici,

AppModuledémarre l'application en chargeant le composant AppComponent. Les composants angulaires sont similaires aux pages et sont utilisés à la fois pour la logique de conception et de programmation.

Une implémentation simple d'AppComponent (app.component.ts) et de sa logique de présentation (app.component.css) est la suivante -

app.component.ts

import { Component } from "@angular/core"; 
@Component(
   {
      selector: "ns-app",
      templateUrl: "app.component.html"
   }
)
export class AppComponent { }

Ici,

templateUrl fait référence à la conception du composant.

app.component.html

<page-router-outlet></page-router-outlet>

Ici,

page-router-outlet est l'endroit où l'application Angular est attachée.

En résumé, le framework Angular est composé de modules similaires au framework NativeScript avec de légères différences. Chaque module de l'Angular aura un composant Angular et un fichier de configuration du routeur (page-routing.mocdule.ts). Le routeur est paramétré par module et il s'occupe de la navigation. Les composants angulaires sont des analogues aux pages dans NativeSctipt core.

Chaque composant aura une conception d'interface utilisateur (page.component.html), une feuille de style (page.component.css) et un fichier de code JavaScript / TypeScript (page.component.ts).

Créons une simple application bare bone pour comprendre le flux de travail de l'application NativeScript.

Création de l'application

Apprenons à créer une application simple à l'aide de NativeScript CLI, tns. tns fournit une commande create à utilisé pour créer un nouveau projet en NativeScript.

La syntaxe de base pour créer une nouvelle application est la suivante -

tns create <projectname> --template <template_name>

Où,

  • Projectname est le nom du projet.

  • template_nameest un modèle de projet. NativeScript fournit de nombreux modèles de démarrage pour créer différents types d'application. Utilisez un modèle basé sur Angular.

Créons un nouveau répertoire nommé NativeScriptSamples pour travailler sur notre nouvelle application. Maintenant, ouvrez un nouveau terminal puis accédez à notre répertoire et tapez la commande ci-dessous -

tns create BlankNgApp --template tns-template-blank-ng

Où, tns-template-blank-ng fait référence à une application mobile vierge basée sur AngularJS.

Production

..... 
..... 
..... 
Project BlankNgApp was successfully created. 
Now you can navigate to your project with $ cd BlankNgApp 
After that you can preview it on device by executing $ tns preview

Maintenant, notre première application mobile, BlankNgApp est créée.

Structure de l'application

Comprenons la structure de l'application NativeScript en analysant notre première application BlankNgApp dans ce chapitre. L'application NativeScript est organisée en plusieurs sections et elles sont les suivantes -

  • Section de configuration

  • Modules de nœud

  • Sources Android

  • Sources iOS

  • Code source de l'application

La structure générale de l'application est la suivante -

│ angular.json 
│ LICENSE 
│ nsconfig.json 
│ package-lock.json 
│ package.json 
│ tsconfig.json 
│ tsconfig.tns.json 
│ tsfmt.json 
│ webpack.config.js 
│
├───App_Resources 
│  ├───Android 
│  │ 
│  └───iOS 
│ 
├───hooks 
│ 
├───node_modules 
| 
└───src 
   │ app.css 
   │ main.ts 
   │ package.json 
   │ 
   └───app 
      │  app-routing.module.ts 
      │  app.component.html 
      │  app.component.ts 
      │  app.module.ts 
      │ 
      └───home 
         home-routing.module.ts 
         home.component.html 
         home.component.ts 
         home.module.ts

Comprenons chaque section de l'application et comment elle nous aide à créer notre application.

Section de configuration

Tous les fichiers à la racine de l'application sont des fichiers de configuration. Le format des fichiers de configuration est au format JSON, ce qui aide le développeur à comprendre facilement les détails de la configuration. L'application NativeScript s'appuie sur ces fichiers pour obtenir toutes les informations de configuration disponibles. Passons en revue tous les fichiers de configuration de cette section.

package.json

Les fichiers package.json définissent l'identité (id) de l'application et de tous les modules dont l'application dépend pour son bon fonctionnement. Voici notre package.json -

{ 
   "nativescript": {
      "id": "org.nativescript.BlankNgApp",
      "tns-android": {
         "version": "6.3.1"
      }, "tns-ios": {
         "version": "6.3.0"
      } 
   }, "description": "NativeScript Application", 
   "license": "SEE LICENSE IN <your-license-filename>", 
   "repository": "<fill-your-repository-here>", 
   "dependencies": { 
      "@angular/animations": "~8.2.0", 
      "@angular/common": "~8.2.0", 
      "@angular/compiler": "~8.2.0", 
      "@angular/core": "~8.2.0", 
      "@angular/forms": "~8.2.0", 
      "@angular/platform-browser": "~8.2.0", 
      "@angular/platform-browser-dynamic": "~8.2.0", 
      "@angular/router": "~8.2.0", 
      "@nativescript/theme": "~2.2.1", 
      "nativescript-angular": "~8.20.3", 
      "reflect-metadata": "~0.1.12", 
      "rxjs": "^6.4.0", 
      "tns-core-modules": "~6.3.0", 
      "zone.js": "~0.9.1" 
   }, 
   "devDependencies": { 
      "@angular/compiler-cli": "~8.2.0", 
      "@ngtools/webpack": "~8.2.0", 
      "nativescript-dev-webpack": "~1.4.0", 
      "typescript": "~3.5.3" 
   }, 
   "gitHead": "fa98f785df3fba482e5e2a0c76f4be1fa6dc7a14", 
   "readme": "NativeScript Application" 
}

Ici,

Identity of the application (nativescript/id)- Définit l'ID de l'application comme org.nativescript.BlankNgApp. Cet identifiant est utilisé pour publier notre application sur le Play Store ou iTunes. Cet identifiant sera notre identifiant d'application ou le nom du package.

Dependencies (dependencies)- Spécifie tous nos modules de nœuds dépendants. Étant donné que l'implémentation NativeScript par défaut dépend de Angular Framework, les modules Angular sont inclus.

Development dependencies- Spécifie tous les outils dont dépend l'application. Depuis, nous développons notre application en TypeScript, elle inclut le typographie comme l'un des modules dépendants.

angular.json - Informations de configuration du cadre angulaire.

nsconfig.json - Informations de configuration du framework NativeScript.

tsconfig.json, tsfmt.json & tsconfig.tns.json - Informations de configuration du langage TypeScript

webpack.config.js - Configuration WebPack écrite en JavaScript.

Modules de nœud

Comme les projets NativeScript sont des projets basés sur des nœuds, il stocke toutes ses dépendances dans le dossier node_modules. Nous pouvons utiliser npm (npm install) ou tns pour télécharger et installer toutes les dépendances d'application dans le node_moduels.

Code source Android

NativeScript génère automatiquement le code source Android et placez-le dans le dossier App_Resources \ Android. Il sera utilisé pour créer une application Android à l' aide du SDK Android

code source iOS

NativeScript génère automatiquement le code source iOS et placez-le dans le dossier App_Resources \ iOS. Il sera utilisé pour créer une application iOS à l'aide du SDK iOS et XCode

Code source de l'application

Le code d'application réel est placé dans le dossier src. Notre application contient les fichiers ci-dessous dans le dossier src.

└───src 
   │ app.css 
   │ main.ts 
   │ package.json 
   │ 
   └───app 
   │ app-routing.module.ts 
   │ app.component.html 
   │ app.component.ts 
   │ app.module.ts 
   │ 
   └───home 
         home-routing.module.ts 
         home.component.html 
         home.component.ts 
         home.module.ts

Laissez-nous comprendre le but de tous les fichiers et comment ils sont organisés dans cette section -

Étape 1

main.ts - Point d'entrée de l'application.

// this import should be first in order to load some required settings (like globals and reflect-metadata) 
import { platformNativeScriptDynamic } from "nativescript-angular/platform";
import { AppModule } from "./app/app.module"; 
platformNativeScriptDynamic().bootstrapModule(AppModule);

Ici, nous avons défini l'AppModule comme module d'amorçage de l'application.

Étape 2

app.css - La feuille de style principale de l'application est comme indiqué ci-dessous -

@import "~@nativescript/theme/css/core.css"; 
@import "~@nativescript/theme/css/brown.css"; 
/* Place any CSS rules you want to apply on both iOS and Android here. 
This is where the vast majority of your CSS code goes. */

Ici,

app.css importe la feuille de style principale et la feuille de style des thèmes de couleur marron du framework NativeScript.

Étape 3

app \ app.module.ts - Module racine de l'application.

import { NgModule, NO_ERRORS_SCHEMA } from "@angular/core";
import { NativeScriptModule } from "nativescript-angular/nativescript.module";
import { AppRoutingModule } from "./app-routing.module";
import { AppComponent } from "./app.component";
@NgModule(
   {
      bootstrap: [
         AppComponent
      ], 
      imports: [
         NativeScriptModule,
         AppRoutingModule
      ], 
      declarations: [
         AppComponent
      ], schemas: [
         NO_ERRORS_SCHEMA
      ]
   }
)
export class AppModule { }

Ici,

AppModule est créé sur la base de NgModule et définit les composants et les modules de l'application. Il importe deux modules NativeScriptModule et AppRoutingModule et un composant, AppComponent. Il définit également AppComponent comme composant racine de l'application.

Étape 4

app.component.ts - Composant racine de l'application.

import { Component } from "@angular/core"; 
@Component(
   { 
      selector: "ns-app", 
      templateUrl: "app.component.html" 
   }
) 
export class AppComponent { }

Ici,

AppComponent définit le modèle et la feuille de style du composant. Le modèle est conçu en HMTL simple à l'aide de composants d'interface utilisateur NativeScript.

Étape 5

app-routing.module.ts - Module de routage pour l'AppModule

import { NgModule } from "@angular/core"; 
import { Routes } from "@angular/router"; 
import { NativeScriptRouterModule } from "nativescript-angular/router"; 
const routes: Routes = [
   { path: "", redirectTo: "/home", pathMatch: "full" },
   { path: "home", loadChildren: () =>
   import("~/app/home/home.module").then((m) => m.HomeModule) } 
];
@NgModule(
   {
      imports: [NativeScriptRouterModule.forRoot(routes)], 
      exports: [NativeScriptRouterModule] 
   }
)
export class AppRoutingModule { }

Ici,

AppRoutingModule utilise le NativeScriptRouterModule et définit les routes de l'AppModule. Il redirige essentiellement le chemin vide vers / home et pointe le / home vers HomeModule.

Étape 6

app \ home \ home.module.ts - Définit un nouveau module, HomeModule.

import { NgModule, NO_ERRORS_SCHEMA } from "@angular/core";
import { NativeScriptCommonModule } from "nativescript-angular/common";
import { HomeRoutingModule } from "./home-routing.module";
import { HomeComponent } from "./home.component";
@NgModule(
   {
      imports: [
         NativeScriptCommonModule,
         HomeRoutingModule
      ],
      declarations: [
         HomeComponent
      ],
      schemas: [
         NO_ERRORS_SCHEMA
      ]
   }
)
export class HomeModule { }

Ici,

HomeModule importe deux modules, HomeRoutingModule et NativeScriptCommonModule et un composant HomeComponent

Étape 7

app \ home \ home.component.ts - Définit le composant Home et utilisé comme page d'accueil de l'application.

import { Component, OnInit } from "@angular/core";
@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. 
   } 
}

Ici,

HomeComponent définit le modèle et le sélecteur du composant d'origine.

Étape 8

app \ home \ home-routing.module.ts - Module de routage pour HomeModule et utilisé pour définir le routage pour le module d'accueil.

import { NgModule } from "@angular/core"; 
import { Routes } from "@angular/router"; 
import { NativeScriptRouterModule } from "nativescript-angular/router"; 
import { HomeComponent } from "./home.component"; 
const routes: Routes = [
   { path: "", component: HomeComponent } 
]; 
@NgModule(
   { 
      imports: [NativeScriptRouterModule.forChild(routes)], 
      exports: [NativeScriptRouterModule] 
   }
) 
export class HomeRoutingModule { }

Ici,

HomeRoutingModule a défini le chemin vide vers HomeComponent.

Étape 9

app.component.html et home.component.html - Ils sont utilisés pour concevoir l'interface utilisateur de l'application à l'aide de composants d'interface utilisateur NativeScript.

Exécutez votre application

Si vous souhaitez exécuter votre application sans utiliser d'appareil, tapez la commande ci-dessous -

tns preview

Après avoir exécuté cette commande, cela générera un code QR pour scanner et se connecter à votre appareil.

Production

QRCode

Le code QR est maintenant généré et connectez-vous à PlayGround à l'étape suivante.

NativeScript PlayGround

Ouvrez l'application NativeScript PlayGround sur votre mobile iOS ou Android, puis choisissez l' option Scanner le code QR . Cela ouvrira la caméra. Focalisez le code QR affiché sur la console. Cela scannera le code QR. La numérisation du code QR déclenchera la construction de l'application, puis synchronisera l'application avec l'appareil comme indiqué ci-dessous -

Copying template files... 
Platform android successfully added. v6.3.1 
Preparing project... 
File change detected. Starting incremental webpack compilation... 
webpack is watching the files… 
Hash: 1f38aaf6fcda4e082b88 
Version: webpack 4.27.1 
Time: 9333ms 
Built at: 01/04/2020 4:22:31 PM
               Asset          Size        Chunks         Chunk Names 
               0.js           8.32 KiB     0     [emitted] 
          bundle.js           22.9 KiB    bundle [emitted] bundle 
       package.json          112 bytes           [emitted] 
         runtime.js             73 KiB   runtime [emitted] runtime 
tns-java-classes.js            0 bytes  [emitted] 
          vendor.js            345 KiB   vendor  [emitted] vendor 
Entrypoint bundle = runtime.js vendor.js bundle.js 
[../$$_lazy_route_resource lazy recursive] ../$$_lazy_route_resource lazy 
namespace object 160 bytes {bundle} [built] [./app.css] 1.18 KiB {bundle} [built] [./app/app-routing.module.ts] 688 bytes {bundle} [built] 
[./app/app.component.html] 62 bytes {bundle} [built] 
[./app/app.component.ts] 354 bytes {bundle} [built] 
[./app/app.module.ts] 3.22 KiB {bundle} [built] 
[./app/home/home.module.ts] 710 bytes {0} [built] 
[./main.ts] 1.84 KiB {bundle} [built] 
[@angular/core] external "@angular/core" 42 bytes {bundle} [built] [nativescript-angular/nativescript.module] external "nativescript-
angular/nativescript.module" 42 bytes {bundle} [built] 
[nativescript-angular/platform] external "nativescript-angular/platform" 42 
bytes {bundle} [built] [tns-core-modules/application] external "tns-core-
modules/application" 42 bytes {bundle} [built] 
[tns-core-modules/bundle-entry-points] external "tns-core-modules/bundle-entry-points" 42 
bytes {bundle} [built] 
[tns-core-modules/ui/frame] external "tns-core-
modules/ui/frame" 42 bytes {bundle} [built] 
[tns-core-modules/ui/frame/activity] external "tns-core-
modules/ui/frame/activity" 42 bytes {bundle} [built] 
   + 15 hidden modules Webpack compilation complete. Watching for file changes. 
Webpack build done! 
Project successfully prepared (android) 
Start sending initial files for device Bala Honor Holly (ff5e8622-7a01-4f9c-
b02f-3dc6d4ee0e1f). 
Successfully sent initial files for device Bala Honor Holly (ff5e8622-7a01-4f9c-b02f-3dc6d4ee0e1f). 
LOG from device Bala Honor Holly: HMR: Hot Module Replacement Enabled. Waiting for signal. 
LOG from device Bala Honor Holly: Angular is running in the development mode. 
Call enableProdMode() to enable the production mode.

Production

Après la numérisation, vous devriez voir votre BlankNgApp sur votre appareil. Il est montré ci-dessous -

Exécutez votre application sur l'appareil

Si vous souhaitez tester l'appareil connecté dans votre application, vous pouvez le vérifier à l'aide de la syntaxe ci-dessous -

'tns device <Platform> --available-devices'

Après cela, vous pouvez exécuter votre application en utilisant la commande ci-dessous -

tns run

La commande ci-dessus est utilisée pour créer vos applications localement et les installer sur des appareils Andriod ou iOS. Si vous souhaitez exécuter votre application sur un simulateur Android, tapez la commande ci-dessous -

tns run android

Pour les appareils iOS, vous pouvez suivre la commande ci-dessous -

tns run ios

Cela initialisera l'application sur un appareil Android / iOS. Nous en discuterons plus en détail dans les prochains chapitres.

LiveSync

NativeScript fournit une synchronisation en temps réel des modifications de l'application vers l'application de prévisualisation. Laissez-nous ouvrir le projet en utilisant l'un de vos éditeurs préférés (Visual Studio Code serait le choix idéal pour une meilleure visualisation). Ajoutons quelques changements dans notre code et voyons comment cela sera détecté dans LiveSync.

Maintenant, ouvrez le fichier app.css et il aura le contenu ci-dessous -

@import "~@nativescript/theme/css/core.css"; 
@import "~@nativescript/theme/css/blue.css"; 
/* Place any CSS rules you want to apply on both iOS and Android here. 
This is where the vast majority of your CSS code goes. */

Ici, la déclaration d'importation indique le jeu de couleurs de notre application. Changeons le jeu de couleurs bleu enbrown jeu de couleurs comme spécifié ci-dessous -

@import "~@nativescript/theme/css/core.css"; 
@import "~@nativescript/theme/css/brown.css"; 
/* Place any CSS rules you want to apply on both iOS and Android here. 
This is where the vast majority of your CSS code goes. */

L'application de notre appareil s'actualise et vous devriez voir une ActionBar de couleur marron comme indiqué ci-dessous -

Production

Vous trouverez ci-dessous la page d'accueil de BlankNgApp - Thème marron.

NativeScript fournit de nombreux modèles prêts à l'emploi pour créer une application vierge simple mais entièrement fonctionnelle à une application complexe basée sur des onglets.

Utilisation du modèle

Comme appris précédemment, une nouvelle application peut être créée en utilisant create sous-commande de la commande tns.

tns create <app-name> --template <tns-template-name>

Ici,

tns-template-name est le nom du modèle.

Si vous souhaitez créer un modèle avec une page et sans styles personnalisés à l'aide de JavaScript, utilisez la commande ci-dessous -

tns create <app-name> --template tns-template-blank

Le même modèle ci-dessus peut être créé en utilisant TypeScript comme suit -

tns create <app-name> --template tns-template-blank-ts

Modèle de navigation

Le modèle de navigation est utilisé pour créer une application modérée à complexe. Il est livré avecSideDrawer composant avec plusieurs pages. SideDrawerLe composant contient une vue masquée pour l'interface utilisateur de navigation ou les paramètres communs. Utilisez la commande ci-dessous pour créer une application basée sur la navigation -

tns create <app-name> --template tns-template-drawer-navigation

Modèle de navigation par onglets

Le modèle de navigation par onglets est utilisé pour créer une application basée sur des onglets. Il est livré avecTabViewcomposant avec plusieurs pages. Utilisez la commande ci-dessous pour créer une application basée sur un onglet -

tns create <app-name> --template tns-template-tab-navigation

Modèle principal-détail

Le modèle Master-Detail est utilisé pour créer une application basée sur une liste avec une page de détail pour chaque élément de la liste.

tns create <app-name> --template tns-template-master-detail

Modèle personnalisé

Pour créer un modèle personnalisé simple, nous devons cloner des modèles vierges. Comme vous le savez déjà, NativeScript prend en charge les modèles JavaScript, TypeScript, Angular et Vue.js afin que vous puissiez choisir n'importe quel langage et créer votre langage personnalisé.

Par exemple, clonez un modèle simple et personnalisé à partir du référentiel git en utilisant la commande ci-dessous -

git clone https://github.com/NativeScript/template-blank-ts.git

Maintenant, il créera la structure de l'application mobile afin que vous puissiez effectuer des modifications et exécuter votre appareil Android / iOS. Cette structure basée sur une liste de lignes directrices. Voyons les lignes directrices en bref.

Structure

Votre modèle personnalisé doit répondre aux exigences suivantes -

  • Ne placez pas votre code dans le dossier racine de votre application.

  • Créez un dossier séparé et ajoutez une zone de fonctionnalités à l'intérieur.

  • Les modèles de page, de vue et de service doivent être placés dans la zone des fonctionnalités. Cela aide à créer un code net et propre.

  • Créer un dossier de page et place à l' intérieur .ts, .xml, .scss / css, etc. , les fichiers.

package.json

Placez le fichier package.json dans le dossier racine de votre modèle d'application. Fournissez une valeur pour la propriété name en utilisant le format -

{
   "name": "tns-template-blank-ts", 
   displayName": "template-blank", 
}

Attribuez une valeur à la propriété version. Il est défini ci-dessous -

"version": "3.2.1",

Attribuez une valeur à la propriété principale en spécifiant le point d'entrée principal de votre application. Il est défini ci-dessous -

"main": "app.js",

Attribuez une valeur à la propriété android. Il est défini ci-dessous -

"android": { 
   "v8Flags": "--expose_gc" 
},

La propriété du référentiel doit être spécifiée dans votre code comme suit -

"repository": { 
   "type": "git", 
   "url": "https://github.com/NativeScript/template-master-detail-ts" 
},

Style

Importez des styles et des thèmes dans votre modèle d'application en utilisant la syntaxe ci-dessous -

@import '~nativescript-theme-core/scss/light';

Nous pouvons également attribuer une couleur d'arrière-plan personnalisée en utilisant le code ci-dessous -

/* Colors */ 
$background: #fff; 
$primary: lighten(#000, 13%);

NativeScript fournit un grand ensemble de composants d'interface utilisateur et sont appelés «widgets». Chaque widget effectue une tâche spéciale et est livré avec un ensemble de méthodes. Comprenons les widgets NativeScript en détail dans cette section.

Bouton

Button est un composant pour exécuter une action d'événement tap. Lorsqu'un utilisateur appuie sur le bouton, il exécute les actions correspondantes. Il est défini ci-dessous -

<Button text="Click here!" tap="onTap"></Button>

Ajoutons le bouton dans notre BlankNgApp comme ci-dessous -

Étape 1

Ouvrez le src\app\home\home.component.html. Ceci est la page de conception de l'interface utilisateur de notre composant d'accueil.

Étape 2

Ajoutez un bouton à l'intérieur du GirdLayoutcomposant. Le code complet est le suivant -

<ActionBar> 
   <Label text="Home"></Label> 
</ActionBar> 
<GridLayout> 
   <button text="Click Here!"></button> 
</GridLayout>

Production

Ci-dessous la sortie du bouton -

Étape 3

Nous pouvons styliser le bouton en utilisant CSS comme spécifié ci-dessous -

<ActionBar> 
   <Label text="Home"></Label> 
</ActionBar> 
<GridLayout> 
   <button text="Click Here!" class="-primary"></button> 
</GridLayout>

Ici, -primary La classe est utilisée pour représenter le bouton principal.

Production

Voici la sortie de ButtonPrimary -

Étape 4

NativeScript fournit une option formatée pour fournir des icônes personnalisées dans le bouton. L'exemple de code est le suivant -

<GridLayout> 
   <Button class="-primary"> 
      <FormattedString> 
         <Span text="&#xf099;" class="fa"></Span> 
         <Span text=" Button.-primary with icon"></Span> 
      </FormattedString> 
   </Button> 
</GridLayout>
.fa {
   font-family: "FontAwesome", "fontawesome-webfont";
}

Ici,

& # xf099 spécifie l'emplacement de l'icône dans la police FontAwesome. Téléchargez la dernière police Font Awesome et placez le fontawesome-webfont.ttf dans le dossier src \ fonts.

Production

Voici la sortie de ButtonPrimary -

Étape 5

Le bouton arrondi peut être créé en utilisant la syntaxe ci-dessous -

<Button text="Button.-primary.-rounded-sm" class="-primary -rounded-sm"></Button>

Production

Voici la sortie de ButtonPrimary -

Étiquette

Le composant Label est utilisé pour afficher du texte statique. Changez la page d'accueil comme ci-dessous -

<GridLayout> 
   <Label text="NativeScript is an open source framework for creating native iOS and Android apps in TypeScript or JavaScript." textWrap="true">
   </Label> 
</GridLayout>

Ici, textWrap enveloppe le contenu de l'étiquette, si l'étiquette s'étend au-delà de la largeur de l'écran.

Production

Voici la sortie de Label -

Champ de texte

Le composant TextField est utilisé pour obtenir des informations de l'utilisateur. Modifions notre page d'accueil comme indiqué ci-dessous -

<GridLayout> 
   <TextField hint="Username" 
      color="lightblue" 
      backgroundColor="lightyellow" 
      height="75px">
   </TextField> 
</GridLayout>

Ici,

  • la couleur représente la couleur du texte

  • backgroundColor représente l'arrière-plan de la zone de texte

  • hauteur représente la hauteur de la zone de texte

Production

Voici la sortie du champ de texte -

Affichage

TextView Component est utilisé pour obtenir le contenu de texte multiligne de l'utilisateur. Modifions notre page d'accueil comme indiqué ci-dessous -

<GridLayout> 
   <TextView loaded="onTextViewLoaded" hint="Enter text" returnKeyType="done" autocorrect="false" maxLength="100"> 
   </TextView> 
</GridLayout>

Ici, maxLength représente la longueur maximale acceptée par TextView .

Production

Voici la sortie de TextView -

Barre de recherche

Ce composant est utilisé pour rechercher des requêtes ou soumettre des requêtes. Il est défini ci-dessous -

<StackLayout> 
   <SearchBar id="bar" hint="click here to search ..."></SearchBar> 
<StackLayout>

Nous pouvons appliquer des styles -

<StackLayout> 
   <SearchBar id="bar" hint="click here to search ..." color="green" backgroundColor="green"></SearchBar> 
</StackLayout>

Voici la sortie de SearchBarStyle -

Commutateur

Le commutateur est basé sur la bascule pour choisir entre les options. L'état par défaut est faux. Il est défini ci-dessous -

<StackLayout> 
   <Switch checked="false" loaded="onSwitchLoaded"></Switch> 
</StackLayout>

La sortie du programme ci-dessus est indiquée ci-dessous -

Glissière

Slider est un composant glissant pour sélectionner une plage numérique. Il est défini ci-dessous -

<Slider value="30" minValue="0" maxValue="50" loaded="onSliderLoaded"></Slider>

La sortie pour le programme ci-dessus est donnée ci-dessous -

Le progrès

Le widget de progression indique la progression d'une opération. La progression actuelle est représentée sous forme de barre. Il est défini ci-dessous -

<StackLayout verticalAlign="center" height="50"> 
   <Progress value="90" maxValue="100" backgroundColor="red" color="green" row="0"></Progress>
</StackLayout>

Voici la sortie du widget Progression -

ActivitéIndicateur

ActivityIndicator montre une tâche en cours. Il est défini ci-dessous -

<StackLayout verticalAlign="center" height="50"> 
   <ActivityIndicator busy="true" color="red" width="50" 
   height="50"></ActivityIndicator> 
</StackLayout>

Voici la sortie pour ActivityIndicator -

Image

Le widget Image est utilisé pour afficher une image. Il peut être chargé en utilisant l'url 'ImageSource'. Il est défini ci-dessous -

<StackLayout class="m-15" backgroundColor="lightgray">
   <Image src="~/images/logo.png" stretch="aspectFill"></Image> 
</StackLayout>

La sortie pour Image Widget est comme indiqué ci-dessous -

WebView

WebView affiche les pages Web. Les pages Web peuvent être chargées à l'aide de l'URL. Il est défini ci-dessous -

<WebView row="1" loaded="onWebViewLoaded" id="myWebView" src="http://www.google.com"></WebView>

La sortie pour le code ci-dessus est comme indiqué ci-dessous -

Sélecteur de date

Le composant DatePicker est utilisé pour choisir la date. Il est défini ci-dessous -

<StackLayout class="m-15" backgroundColor="lightgray"> 
   <DatePicker year="1980" month="4" day="20" verticalAlignment="center"></DatePicker> 
</StackLayout>

La sortie du composant DatePicker est comme indiqué ci-dessous -

TimePicker

Le composant TimePicker est utilisé pour choisir l'heure. Il est défini ci-dessous -

<StackLayout class="m-15" backgroundColor="lightgray"> 
<TimePicker hour="9" 
   minute="25" 
   maxHour="23" 
   maxMinute="59" 
   minuteInterval="5"> 
</TimePicker> 
</StackLayout>

Voici la sortie du composant TimePicker -

NativeScript fournit une collection de composants de conteneur dans le seul but de disposer le composant de widget d'interface utilisateur. Les conteneurs de disposition agissent comme le composant parent et peuvent avoir un ou plusieurs composants enfants. Tous les composants enfants d'un conteneur de disposition peuvent être organisés en fonction de la technique fournie par son conteneur de disposition parent.

NativeScript prend en charge six conteneurs de dispositions et ils sont les suivants:

  • Conteneur de mise en page absolu

  • Conteneur de disposition de quai

  • Conteneur de disposition de grille

  • Conteneur de disposition de pile

  • Conteneur de mise en page Wrap

  • Conteneur de mise en page FlexBox

Apprenons en détail tous les concepts de conteneur de mise en page dans ce chapitre.

Disposition absolue

AbsoluteLayoutcontainer est le conteneur de mise en page le plus simple de NativeScript. AbsoluteLayout n'applique aucune contrainte sur ses enfants et placera ses enfants à l'intérieur en utilisant un système de coordonnées bidimensionnel avec le coin supérieur gauche comme origine.

AbsoluteLayout utilise quatre propriétés de ses enfants pour les positionner et elles sont les suivantes -

top - Définit le placement de l'enfant depuis l'origine en se déplaçant vers le bas dans la direction y.

left - Définit le placement de l'enfant depuis l'origine en se déplaçant latéralement dans la direction x.

width - Définit la largeur de l'enfant.

height - Définit la hauteur de l'enfant.

Ajoutons le conteneur AbsoluteLayout dans la page d'accueil de notre application comme ci-dessous -

<ActionBar> 
   <Label text="Home"></Label> 
</ActionBar> 

<AbsoluteLayout width="200" height="300" backgroundColor="blue"> 
   <Label text="Top Left" left="0" top="0" width="100" height="150" backgroundColor="green">
   </Label> 
   <Label text="Top Right" left="100" top="0" width="100" height="150" backgroundColor="blue"></Label> 
   <Label text="Bottom Left" left="0" top="150" width="100" height="150" backgroundColor="orange">
   </Label>
   <Label text="Bottom Right" left="100" top="150" width="100" height="150" backgroundColor="red"></Label> 
</AbsoluteLayout>

Production

La sortie d'AbsoluteLayout est comme donnée ci-dessous -

DockLayout

DocklayoutLe composant container permet à ses enfants de s'y ancrer. Chaque côté du conteneur (haut, bas, gauche, droite) peut ancrer un composant enfant. Le conteneur DockLayout utilise la propriété dock de ses enfants pour les ancrer correctement.

Les valeurs possibles de la propriété dock sont les suivantes -

top - Le conteneur de mise en page ancre le composant enfant dans le coin supérieur.

bottom - Le conteneur de mise en page ancre le composant enfant dans le coin inférieur.

left - Le conteneur de mise en page ancre le composant enfant dans le coin gauche.

right - Le conteneur de mise en page ancre le composant enfant dans le coin droit.

Par défaut, DockLayoutconteneur ancre son dernier composant enfant. Il peut remplacer en définissant sa propriété stretchLastChild sur zéro.

Ajoutons DockLayout conteneur dans la page d'accueil de notre application comme ci-dessous -

<ActionBar> 
   <Label text="Home"></Label> 
</ActionBar> 
<DockLayout width="250" height="300" backgroundColor="blue" stretchLastChild="false"> 
   <Label text="left" dock="left" width="50" backgroundColor="green"></Label> 
   <Label text="top" dock="top" height="50" backgroundColor="orange"></Label> 
   <Label text="right" dock="right" width="50" backgroundColor="red"></Label< 
   <Label text="bottom" dock="bottom" height="50" 
   backgroundColor="orange"></Label> 
</DockLayout>

Production

Voici la sortie pour DockLayout -

Disposition de la grille

Le composant de conteneur GridLayout est l'un des conteneurs de disposition complexes et organise les éléments enfants au format tabulaire avec des lignes et des colonnes. Par défaut, il comporte une ligne et une colonne. Il a les propriétés suivantes -

columns- Utilisé pour représenter la largeur par défaut de chaque colonne séparée par,. Les valeurs possibles sont number, * et auto keyword.

Où,

  • nombre indique une largeur de colonne absolue.

  • indique la largeur d'une colonne par rapport aux autres colonnes. Il peut être précédé d'un nombre pour indiquer combien de fois la largeur de la colonne doit être relative à une autre colonne. Par exemple, 2 * indique la largeur de la colonne doit être 2 fois la largeur de la plus petite colonne.

  • auto indique la largeur de la colonne aussi large que son enfant le plus large.

Par exemple, *, 2 * signifie deux colonnes et la seconde aura deux fois la taille de la première colonne.

rows - Utilisé pour représenter la hauteur par défaut de chaque ligne séparée par,. La représentation de la valeur est similaire aux colonnes.

GridLayout utilise les propriétés spécifiées ci-dessous de ses enfants pour les mettre en page -

row - Numéro de ligne

col - Numéro de colonne

rowSpan - nombre total de lignes que le contenu enfant couvre dans une mise en page.

colSpan - nombre total de colonnes que le contenu enfant couvre dans une mise en page.

Ajoutons le conteneur GridLayout dans la page d'accueil de notre application comme ci-dessous -

<ActionBar> 
   <Label text="Home"></Label> 
</ActionBar> 
<GridLayout columns="50, auto, *" rows="50, auto, *" width="210" height="210"
   backgroundColor="blue"> 
   <Label text="Row: 0; Column 0" row="0" col="0" backgroundColor="green"></Label> 
   <Label text="Row: 0; Column 1" row="0" col="1" colSpan="1" backgroundColor="brown"></Label> 
   <Label text="Row: 1; Column 0" row="1" col="0" rowSpan="1" backgroundColor="red"></Label> 
   <Label text="Row: 1; Column 1" row="1" col="1" backgroundColor="orange"></Label> 
</GridLayout>

Production

Voici la sortie pour GridLayout -

StackLayout

StackLayout organise ses enfants dans une ligne unidimensionnelle horizontalement ou verticalement. Il peut être dimensionné en fonction de l'espace dans la mise en page à l'aide des options de mise en page. Il a une propriété d'orientation qui peut être utilisée pour spécifier la direction, horizontale ou verticale.

Ajoutons le conteneur StackLayout dans la page d'accueil de notre application comme ci-dessous -

<ActionBar> 
   <Label text="Home"></Label> 
</ActionBar> 
<StackLayout orientation="vertical" width="200" height="200" backgroundColor="blue"> 
   <Label text="Label1" width="50" height="50" backgroundColor="green"></Label> 
   <Label text="Label2" width="50" height="50" backgroundColor="brown"></Label> 
   <Label text="Label3" width="50" height="50" backgroundColor="red"></Label> 
   <Label text="Label4" width="50" height="50" backgroundColor="orange"></Label> 
</StackLayout>

Production

La sortie pour StackLayout est comme indiqué ci-dessous -

WrapLayout

WrapLayout est utilisé pour envelopper le contenu sur de nouvelles lignes ou colonnes.

Il a les trois propriétés suivantes -

orientation - afficher horizontalement ou verticalement.

itemWidth - largeur de mise en page pour chaque enfant.

itemHeight - hauteur de mise en page pour chaque enfant.

Ajoutons le conteneur WrapLayout dans la page d'accueil de notre application comme ci-dessous -

<ActionBar> 
   <Label text="Home"></Label> 
</ActionBar> <WrapLayout orientation="horizontal" width="200" height="200" backgroundColor="blue">
   <Label text="Label1" width="70" height="70" backgroundColor="green"></Label> 
   <Label text="Label2" width="70" height="70" backgroundColor="brown"></Label 
   <Label text="Label3" width="70" height="70" backgroundColor="red"></Label> 
   <Label text="Label4" width="70" height="70" backgroundColor="orange"></Label> 
</WrapLayout>

Production

Disposition Flexbox

Le composant conteneur FlexboxLayout est l'un des conteneurs de mise en page avancés. Il offre la possibilité de rendre une mise en page simple en mises en page très complexes et sophistiquées. Il est basé sur la CSS Flexbox.

Le composant FlexboxLayout a beaucoup de propriétés et elles sont les suivantes -

flexDirection

Il représente la direction dans laquelle les composants enfants sont disposés. Les valeurs possibles de flexDirection sont les suivantes -

row - Les composants enfants sont disposés côte à côte.

row-reverse - Les composants enfants sont disposés côte à côte mais dans le sens inverse.

column - Les composants enfants sont disposés les uns en dessous des autres.

column-reverse - Les composants enfants sont disposés les uns en dessous des autres mais en sens inverse.

Ajoutons le conteneur FlexLayout dans la page d'accueil de notre application comme ci-dessous -

<ActionBar> 
   <Label text="Home"></Label> 
</ActionBar> 
<FlexboxLayout flexDirection="row"> 
   <Label text="First Item" backgroundColor="red"></Label> 
   <Label text="Second Item" backgroundColor="green"></Label> 
   <Label text="Third Item" backgroundColor="red"></Label> 
   <Label text="Fourth Item" backgroundColor="green"></Label> 
   <Label text="Fifth Item" backgroundColor="red"></Label> 
</FlexboxLayout>

Production

Voici la sortie de FlexLayout - Row -

Maintenant, changeons la valeur flexDirection de ligne en ligne inversée et vérifions comment cela affecte la mise en page.

<ActionBar> 
   <Label text="Home"></Label> 
</ActionBar> <FlexboxLayout flexDirection="row-reverse"> 
   <Label text="First Item" backgroundColor="red"></Label> 
   <Label text="Second Item" backgroundColor="green"></Label> 
   <Label text="Third Item" backgroundColor="red"></Label> 
   <Label text="Fourth Item" backgroundColor="green"></Label> 
   <Label text="Fifth Item" backgroundColor="red"></Label> 
</FlexboxLayout>

Production

Vous trouverez ci-dessous la sortie de Flex Layout - Row Reverse -

Modifions la valeur flexDirection de ligne inversée à colonne et vérifions comment cela affecte la mise en page.

<ActionBar> 
   <Label text="Home"></Label> 
</ActionBar> 
<FlexboxLayout flexDirection="column"> 
   <Label text="First Item" backgroundColor="red"></Label> 
   <Label text="Second Item" backgroundColor="green"></Label> 
   <Label text="Third Item" backgroundColor="red"></Label> 
   <Label text="Fourth Item" backgroundColor="green"></Label> 
   <Label text="Fifth Item" backgroundColor="red"></Label> 
</FlexboxLayout>

Production

La sortie pour FlexLayout - Colonne est donnée ci-dessous -

Modifions la valeur flexDirection de colonne en colonne inversée et vérifions comment cela affecte la mise en page.

<ActionBar> 
   <Label text="Home"></Label> 
</ActionBar> 
<FlexboxLayout flexDirection="column-reverse"> 
   <Label text="First Item" backgroundColor="red"></Label> 
   <Label text="Second Item" backgroundColor="green"></Label> 
   <Label text="Third Item" backgroundColor="red"></Label> 
   <Label text="Fourth Item" backgroundColor="green"></Label> 
   <Label text="Fifth Item" backgroundColor="red"></Label> 
</FlexboxLayout>

Production

Vous trouverez ci-dessous la sortie de FlexLayout - Column Reverse -

flexWrap

Il indique si les composants enfants seront rendus dans une seule ligne / colonne ou s'ils se répartissent sur plusieurs lignes en s'enroulant dans la direction définie par flexDirection.

Les valeurs possibles sont les suivantes -

wrap - Enveloppe les composants enfants, si aucun espace n'est disponible dans la direction donnée (flexDirection).

wrap-reverse - Identique à l'enroulement sauf que le composant s'écoule dans la direction opposée.

Ajoutons la propriété flexWrap, puis définissons sa valeur comme wrap. Ajoutez également trois autres enfants comme indiqué ci-dessous -

<ActionBar> 
   <Label text="Home"></Label> 
&tl;/ActionBar> 
<FlexboxLayout flexDirection="row" flexWrap="wrap"> 
   <Label text="First Item" backgroundColor="red"></Label> 
   <Label text="Second Item" backgroundColor="green"></Label> 
   <Label text="Third Item" backgroundColor="red"></Label> 
   <Label text="Fourth Item" backgroundColor="green"></Label> 
   <Label text="Fifth Item" backgroundColor="red"></Label>
   <Label text="Sixth Item" backgroundColor="green"></Label> 
   <Label text="Seventh Item" backgroundColor="red"></Label> 
   <Label text="Eighth Item" backgroundColor="green"></Label> 
</FlexboxLayout>

Production

Voici la sortie pour flexWrap -

Justifier le contenu

Il représente la manière dont les composants enfants sont organisés les uns par rapport aux autres et à la structure globale. Il a trois propriétés comme spécifié ci-dessous -

flex-end - Il emballe le composant enfant vers la ligne de fin.

space-between - Il emballe le composant enfant en le distribuant uniformément en ligne.

space-around - Similaire à l'espace-entre, sauf qu'il emballe le composant enfant en répartissant uniformément en ligne ainsi qu'un espace égal autour d'eux.

Ajoutons également justifyContent et vérifions comment il se comporte -

<ActionBar> 
   <Label text="Home"></Label>
</ActionBar> 
<FlexboxLayout flexDirection="row" flexWrap="wrap" justifyContent="space-around"> 
   <Label text="First Item" backgroundColor="red"></Label> 
   <Label text="Second Item" backgroundColor="green"></Label> 
   <Label text="Third Item" backgroundColor="red"></Label> 
   <Label text="Fourth Item" backgroundColor="green"></Label> 
   <Label text="Fifth Item" backgroundColor="red"></Label> 
   <Label text="Sixth Item" backgroundColor="green"></Label> 
   <Label text="Seventh Item" backgroundColor="red"></Label> 
   <Label text="Eighth Item" backgroundColor="green"></Label> 
</FlexboxLayout>

Production

Voici la sortie de Flex Layout - JustifyContent -

Le conteneur FlexLayout fournit deux autres propriétés à ses enfants pour spécifier l'ordre et la capacité de réduction. Ils sont les suivants -

order - Il détermine l'ordre dans lequel les enfants du conteneur FlexLayout seront rendus.

flexShrink - Il détermine la capacité des enfants à se réduire au niveau 0.

La navigation permet aux utilisateurs de glisser rapidement vers l'écran de leur choix, de naviguer dans une application ou d'effectuer une action particulière. Le composant de navigation vous aide à implémenter la navigation à l'aide de simples clics de bouton vers des modèles plus complexes.

La navigation diffère considérablement entre la version principale et angulaire de NativeScript. Alors que la navigation du framework de base est la base du processus de navigation, le modèle Angular de NativeScript adopte le concept de navigation de base et l'étend pour le rendre compatible avec le framework Angular.

Voyons à la fois le concept de navigation de base et l'adoption angulaire de la navigation dans ce chapitre.

Concepts de base

Voyons comment la navigation fonctionne dans le noyau NativeScript dans ce chapitre.

Dans NativeScript, la navigation est divisée en quatre catégories différentes en fonction de la direction dans laquelle elle s'applique, comme spécifié ci-dessous -

  • Navigation vers l'avant

  • Navigation arrière

  • Navigation latérale

  • Navigation inférieure

Navigation vers l'avant

La navigation vers l'avant fait référence à la navigation des utilisateurs vers l'écran au niveau suivant de la hiérarchie. Il est basé sur deux composants NativeScript,Frame et Page.

Frame

Frame est le composant de niveau racine pour la navigation. Ce n'est pas un conteneur visible mais agit comme un conteneur pour les transitions entre les pages.

Un exemple simple est le suivant -

<Frame id="featured" defaultPage="featured-page" />

Ici,

Frame navigue vers (ou charge) le composant de page en vedette et le rend.

Page

La page est à côté du composant Frame et agit comme un conteneur pour le composant UI. Un exemple simple est défini ci-dessous -

<Page loaded="onPageLoaded"> 
   <ActionBar title="Item" class="action-bar"></ActionBar>
   <AbsoluteLayout> 
      <Label text="Label"/< 
      <Button text="navigate('another-page')" tap="onTap"/> 
   </AbsoluteLayout> 
</Page>

Ici,

  • Initialement, Page charge tous les composants de l'interface utilisateur de l'écran et le rend.

  • Lorsque l'utilisateur clique sur le bouton, il dirige l'utilisateur vers another-page page.

Navigation arrière

La méthode de navigation arrière permet un mouvement vers l'arrière à travers les écrans dans une application ou entre différentes applications. C'est la direction opposée de la navigation vers l'avant. La méthode goBack () simple est utilisée pour revenir à la page précédente.

Il est défini ci-dessous -

<Page class="page" loaded="onPageLoaded"> 
   <ActionBar title="Item" class="action-bar"></ActionBar> 
   <StackLayout class="home-panel"> 
      <Button class="btn btn-primary" text="Back" tap="goBack"/> 
   </StackLayout> 
</Page>

Ici,

goBack() La méthode sera déclenchée lorsque l'utilisateur appuie sur le bouton. goBack() dirige les utilisateurs vers la page précédente, si elle est disponible.

Navigation latérale

La navigation latérale fait référence à la navigation entre les écrans aux mêmes niveaux de hiérarchie. Il est basé sur le modèle de moyeu. Il est activé via des composants de navigation spécifiques tels que BottomNavigation, Tabs, TabView, SideDrawer et Modal View.

Un exemple simple est défini comme ci-dessous -

<Page class="page" xmlns="http://www.nativescript.org/tns.xsd"> 
   <ActionBar title="Hub" class="action-bar"></ActionBar> 
   <StackLayout class="home-panel"> 
      <Button class="btn btn-primary" text="navigate('featured-page')" tap="navigateToFeatured" /> 
      <Button class="btn btn-primary" text="navigate('search-page')" tap="navigateToSearch" />
   </StackLayout> 
</Page>

Ici,

  • navigateToFeatured La fonction utilise la méthode navigate () pour diriger l'utilisateur vers la page sélectionnée.

  • De même, navigateToSearch La fonction dirigera l'utilisateur vers la page de recherche.

La page hub peut également être atteinte en utilisant la méthode de navigation disponible dans l'écran de la page et on peut sortir de la page hub en utilisant la méthode goBack ().

Un exemple simple est le suivant -

<Page class="page"> 
   <ActionBar title="Item" class="action-bar"></ActionBar> 
   <StackLayout class="home-panel"> 
      <Button class="btn btn-primary" text="navigate('hub-page')" tap="navigateToHub" /> 
      <Button class="btn btn-primary" text="goBack()" tap="goBack" /> 
   </StackLayout> 
</Page>

Navigation par le bas et les onglets

Le style de navigation le plus courant dans les applications mobiles est la navigation par onglets. La navigation par onglets est disposée en bas de l'écran ou en haut sous l'en-tête. Il est réalisé en utilisant le composant TabView et BottomNavigation .

Navigation basée sur angulaire

NativeScript étend son concept de navigation pour s'adapter au concept de routage angulaire. NativeScript fournit un nouveau module, NativeScriptRouterModule en étendant Angular RouterModule.

Le concept de navigation angulaire NativeScript peut être classé en section comme ci-dessous -

  • balise page-router-outlet

  • nsRouterLink attrayant

  • Classe RouterExtension

  • Routeur personnalisé

Apprenons toute la navigation angulaire ci-dessus dans cette section.

Sortie de routeur de page

Comme appris précédemment, page-router-outlet est le remplacement du router-outlet d'Angular. page-router-outlet englobe la stratégie Frame and Page du framework de navigation Nativescript. Chaque page-router-outlet crée un nouveau composant Frame et chaque composant configuré dans la sortie sera encapsulé à l'aide du composant Page. Ensuite, la méthode native de navigation est utilisée pour naviguer vers une autre page / route.

Lien de routeur (nsRouterLink)

nsRouterLink est le remplacement de RouterLink d'Angular. Il permet au composant d'interface utilisateur de créer un lien vers une autre page en utilisant route. nsRouterLink fournit également ci-dessous deux options -

pageTransition- Il est utilisé pour définir l'animation de transition de page. true active la transition par défaut. false désactive la transition. Des valeurs spécifiques telles que slide, fadein, etc. définissent la transition particulière.

clearHistory - true efface l'historique de navigation de nsRouterLink.

Un exemple de code simple est le suivant -

<Button text="Go to Home" [nsRouterLink]="['/home']" 
   pageTransition="slide" clearHistory="true"></Button>

Extension de routeur

NativeScript fournit la classe RouterExtensions et expose la fonction de navigation du noyau NativeScript.

Les méthodes exposées par RouterExtensions sont les suivantes -

  • navigate

  • navigateByUrl

  • back

  • canGoBack

  • backToPreviousPage

  • canGoBackToPreviousPage

Un exemple de code simple utilisant RouterExtensions est le suivant -

import { RouterExtensions } from "nativescript-angular/router"; 
@Component({ 
   // ... 
}) 
export class HomeComponent { 
   constructor(private routerExtensions: RouterExtensions) { } 
}

Stratégie de réutilisation d'itinéraire personnalisée

NativeScript utilise une stratégie de réutilisation d'itinéraire personnalisée (RouterReuseStrategy) pour s'adapter à l'architecture d'une application mobile. Une application mobile diffère sous certains aspects par rapport à une application Web.

Par exemple, la page peut être détruite dans une application Web lorsque l'utilisateur quitte la page et la recrée lorsque l'utilisateur accède à la page. Mais, dans une application mobile, la page sera préservée et réutilisée. Ces concepts sont pris en compte lors de la conception du concept de routage.

Itinéraires

Un module de routage simple dans l'application NativeScript Angular sera comme ci-dessous -

import { NgModule } from "@angular/core"; 
import { Routes } from "@angular/router"; 
import { NativeScriptRouterModule } from "nativescript-angular/router"; 
import { HomeComponent } from "./home.component"; 
import { SearchComponent } from "./search.component"; 
const routes: Routes = [ 
   { path: "", redirectTo: "/home", pathMatch: "full" }, 
   { path: "home", component: HomeComponent }, 
   { path: "search", component: SearchComponent }, 
];
@NgModule({ 
   imports: [NativeScriptRouterModule.forRoot(routes)], 
   exports: [NativeScriptRouterModule] 
}) 
export class AppRoutingModule { }

Ici,

Le module de routage est très similaire à la version Angular à quelques exceptions près. En réalité, NativeScript utilise sa stratégie de navigation de base en l'exposant d'une manière similaire au framework Angular.

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énements 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énements, onButtonTap.

  • Imprimez le nom de l'événement, appuyez sur et sur 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

La liaison de données est l'un des concepts avancés pris en charge par NativeScript. NativeScript suit le concept de liaison de données angulaire aussi étroitement que possible. La liaison de données permet au composant d'interface utilisateur d'afficher / de mettre à jour la valeur actuelle du modèle de données d'application sans aucun effort de programmation.

NativeScript prend en charge deux types de liaison de données. Ils sont les suivants -

One-Way data binding - Mettez à jour l'interface utilisateur chaque fois que le modèle est modifié.

Two-Way data binding- Synchronisez l'interface utilisateur et le modèle. Chaque fois que le modèle est mis à jour, l'interface utilisateur est mise à jour automatiquement et également chaque fois que l'interface utilisateur obtient des données de l'utilisateur (l'interface utilisateur est mise à jour), le modèle sera mis à jour.

Apprenons les deux concepts de cette section.

Liaison de données unidirectionnelle

NativeScript fournit une option simple pour activer la liaison de données unidirectionnelle dans un composant d'interface utilisateur. Pour activer la liaison de données unidirectionnelle, ajoutez simplement un crochet dans la propriété de l'interface utilisateur cible, puis attribuez-lui la propriété du modèle nécessaire.

Par exemple, pour mettre à jour le contenu texte d'un composant Label, changez simplement le code d'interface utilisateur comme ci-dessous -

<Label [text]='this.model.prop' />

Ici,

this.model.prop fait référence à la propriété du modèle, this.model.

Modifions notre BlankNgApp pour comprendre la liaison de données unidirectionnelle.

Étape 1

Ajoutez un nouveau modèle, User (src / model / user.ts) comme suit -

export class User { 
   name: string 
}

Étape 2

Interface utilisateur ouverte de notre composant, src/app/home/home.component.html et mettez à jour le code comme ci-dessous -

<ActionBar> 
   <Label text="Home"></Label> 
</ActionBar>
<GridLayout columns="*" rows="auto, auto, auto"> 
   <Button text="Click here to greet" class="-primary" color='gray' 
      (tap)='onButtonTap($event)' row='1' column='0'>
   </Button> 
   <Label [text]='this.user.name' row='2' column='0' 
      height="50px" textAlignment='center' style='font-size: 16px; 
      font-weight: bold; margin: 0px 32px 0 25px;'>
   </Label> 
</GridLayout>

Ici,

  • Le texte de l'étiquette est défini sur le nom de propriété du modèle utilisateur.

  • L'événement Button tap est associé à la méthode onButtonTap.

Étape 3

Code ouvert du composant home, src/app/home/home.component.ts et mettez à jour le code comme ci-dessous -

import { Component, OnInit } from "@angular/core"; 
import { User } from "../../model/user" 
@Component({
   selector: "Home", 
   templateUrl: "./home.component.html" 
}) 
export class HomeComponent implements OnInit { 
   public user: User; 
   constructor() {
      // Use the component constructor to inject providers. 
      this.user = new User(); 
      this.user.name = "User1"; 
   }
   ngOnInit(): void { 
      // Init your component properties here. 
   } 
   onButtonTap(args: EventData) { 
      this.user.name = 'User2'; 
   } 
}

Ici,

  • le modèle utilisateur est importé

  • L'objet utilisateur est créé dans le constructeur du composant

  • L'événement onButtonTap est implémenté. L'implémentation de onButtonTap met à jour l'objet User et définit le nom de la propriété comme User2

Étape 4

Compilez et exécutez l'application et cliquez sur le bouton pour changer le modèle et cela changera automatiquement le Label texte.

L'état initial et final de l'application est le suivant -

Etat initial

L'état initial de la liaison de données unidirectionnelle est indiqué ci-dessous -

État final

L'état final de la liaison de données unidirectionnelle est indiqué ci-dessous -

Liaison de données bidirectionnelle

NativeScript fournit également une liaison de données bidirectionnelle pour des fonctionnalités avancées. Il lie les données du modèle à l'interface utilisateur et lie également les données mises à jour dans l'interface utilisateur au modèle.

Pour effectuer une liaison de données bidirectionnelle, utilisez la propriété ngModel, puis entourez-la de [] et () comme ci-dessous -

<TextField [(ngModel)] = 'this.user.name'></TextField>

Modifions l'application BlankNgApp pour mieux comprendre la liaison de données bidirectionnelle.

Étape 1

Importez NativeScriptFormsModule dans HomeModule (src/app/home/home.module.ts) comme spécifié ci-dessous -

import { NgModule, NO_ERRORS_SCHEMA } from "@angular/core"; 
import { NativeScriptCommonModule } from "nativescript-angular/common"; 
import { HomeRoutingModule } from "./home-routing.module"; 
import { HomeComponent } from "./home.component"; 
import { NativeScriptFormsModule } from "nativescript-angular/forms";
@NgModule({ 
   imports: [ 
      NativeScriptCommonModule, 
      HomeRoutingModule, 
      NativeScriptFormsModule 
   ], 
   declarations: [ 
      HomeComponent 
   ], 
   schemas: [ 
      NO_ERRORS_SCHEMA 
   ]
}) 
export class HomeModule { }

Ici,

NativeScriptFormsModule active la liaison de données bidirectionnelle. Sinon, la liaison de données bidirectionnelle ne fonctionnera pas comme prévu.

Étape 2

Modifiez l'interface utilisateur du composant d'accueil comme indiqué ci-dessous -

<ActionBar> <Label text="Home"></Label></ActionBar> 
<GridLayout columns="*" rows="auto, auto"> 
   <TextField hint="Username" row='0' column='0' color="gray" 
      backgroundColor="lightyellow" height="75px" [(ngModel)]='this.user.name'>
   </TextField> 
   <Label [text]='this.user.name' row='1' column='0' height="50px" 
      textAlignment='center' style='font-size: 16px; font-weight: bold; 
      margin: 0px 32px 0 25px;'>
   </Label> 
</GridLayout>

Ici,

La propriété de texte du composant Label est définie avec une liaison de données unidirectionnelle. Si l'utilisateur du modèle est mis à jour, sa propriété text sera automatiquement mise à jour.

Le composant TextField définit le ngModel comme this.user.name. Si l'utilisateur du modèle est mis à jour, sa propriété text sera automatiquement mise à jour. En même temps, si l'utilisateur modifie la valeur de TextField, le modèle est également mis à jour. Si le modèle est mis à jour, il déclenchera également les modifications de propriété de texte de Label. Ainsi, si l'utilisateur modifie les données, elles s'afficheront dans la propriété text de Label.

Étape 3

Exécutez l'application et essayez de modifier la valeur de la zone de texte.

L'état initial et final de l'application sera similaire à celui spécifié ci-dessous -

Etat initial

Liaison de données bidirectionnelle - L'état initial est indiqué ci-dessous -

État final

Liaison de données bidirectionnelle - L'état final est indiqué ci-dessous -

Un module NativeScript contient un ensemble de fonctionnalités associées regroupées sous forme de bibliothèque unique. Apprenons les modules fournis par le framework NativeScript.

Il contient les fonctionnalités de base du framework NativeScript. Laissez-nous comprendre les modules de base de ce chapitre.

Application

L'application contient une mise en œuvre spécifique à la plate-forme de l'application mobile. Le module de base simple est défini ci-dessous -

const applicationModule = require("tns-core-modules/application");

Console

Le module de console est utilisé pour enregistrer le message. Il a les méthodes suivantes -

console.log("My FirstApp project"); 
console.info("Native apps!"); 
console.warn("Warning message!"); 
console.error("Exception occurred");

paramètres de l'application

Le module de paramètres d'application contient une méthode pour gérer les paramètres d'application. Pour ajouter ce module, nous devons ajouter le code suivant -

const appSettings = require("tns-core-modules/application-settings");

Quelques méthodes disponibles dans les paramètres d'application sont les suivantes -

  • setBoolean (key: string, value: boolean) - définir un objet booléen

  • setNumber (key: string, value: number) - objet set number

  • setString (clé: chaîne, valeur: chaîne) - définit l'objet chaîne

  • getAllKeys () - Contient toutes les clés stockées

  • hasKey (key: string) - vérifier si une clé est présente ou non

  • clear - efface les valeurs stockées

  • remove - supprime toute entrée basée sur la clé.

Voici un exemple simple d'utilisation des paramètres d'application:

function onNavigatingTo(args) { 
   appSettings.setBoolean("isTurnedOff", false);
   appSettings.setString("name", "nativescript"); 
   appSettings.setNumber("locationX", 54.321); 
   const isTurnedOn = appSettings.getBoolean("isTurnedOn"); 
   const username = appSettings.getString("username"); 
   const locationX = appSettings.getNumber("locationX"); 
   // Will return "not present" if there is no value for "noKey" 
   const someKey = appSettings.getString("noKey", "not present"); 
}
exports.onNavigatingTo = onNavigatingTo; 
function onClear() {
   // Removing a single entry via its key name 
   appSettings.remove("isTurnedOff"); 
   // Clearing the whole settings 
   appSettings.clear(); 
}

http

Ce module est utilisé pour la manipulation httpdemande et réponse. Pour ajouter ce module dans votre application, ajoutez le code suivant -

const httpModule = require("tns-core-modules/http");

Nous pouvons envoyer des données en utilisant les méthodes suivantes -

getString- Il est utilisé pour faire une demande et télécharge les données de l'URL sous forme de chaîne. Il est défini ci-dessous -

httpModule.getString("https://.../get").then(
   (r) => { 
      viewModel.set("getStringResult", r); 
   }, (e) => 
   { 
   }
);

getJSON- Il est utilisé pour accéder aux données de JSON. Il est défini ci-dessous -

httpModule.getJSON("https://.../get").then((r) => { 
}, (e) => { 
});

getImage- télécharge le contenu à partir de l'URL spécifiée et renvoie l'objet ImageSource. Il est défini ci-dessous -

httpModule.getImage("https://.../image/jpeg").then((r) => { 
}, (e) => { 
});

getFile - Il a deux arguments URL et chemin de fichier.

  • URL - télécharge les données.

  • File path- enregistrer les données URL dans le fichier. Il est défini ci-dessous -

httpModule.getFile("https://").then((resultFile) => { 
}, (e) => { 
});

request- Il a un argument d'options. Il est utilisé pour demander des options et renvoyer l'objet HttpResponse. Il est défini ci-dessous -

httpModule.request({ 
   url: "https://.../get", 
   method: "GET" 
}).then((response) => { 
}, (e) => { 
});

Source de l'image

Le module image-source est utilisé pour enregistrer l'image. Nous pouvons ajouter ce module en utilisant la déclaration ci-dessous -

const imageSourceModule = require("tns-core-modules/image-source");

Si vous souhaitez charger des images à partir de la ressource, utilisez le code ci-dessous -

const imgFromResources = imageSourceModule.fromResource("icon");

Pour ajouter une image à partir d'un fichier local, utilisez la commande ci-dessous -

const folder = fileSystemModule.knownFolders.currentApp(); 
const path = fileSystemModule.path.join(folder.path, "images/sample.png"); 
const imageFromLocalFile = imageSourceModule.fromFile(path);

Pour enregistrer l'image dans le chemin du fichier, utilisez la commande ci-dessous -

const img = imageSourceModule.fromFile(imagePath); 
const folderDest = fileSystemModule.knownFolders.documents(); 
const pathDest = fileSystemModule.path.join(folderDest.path, "sample.png"); 
const saved = img.saveToFile(pathDest, "png"); if (saved) { 
   console.log(" sample image saved successfully!"); 
}

Minuteur

Ce module est utilisé pour exécuter du code à des intervalles de temps spécifiques. Pour ajouter cela, nous devons utiliserrequire -

const timerModule = require("tns-core-modules/timer");

Il repose sur deux méthodes -

setTimeout- Il est utilisé pour retarder l'exécution. Il est représenté en millisecondes.

setInterval - Il est utilisé pour appliquer des répétitions à des intervalles spécifiques.

Trace

Ce module est utile pour le débogage. Il donne les informations de journalisation. Ce module peut être représenté par -

const traceModule = require("tns-core-modules/trace");

Si vous souhaitez activer dans votre application, utilisez la commande ci-dessous -

traceModule.enable();

ui / image-cache

Le module image-cache est utilisé pour gérer les demandes de téléchargement d'images et met en cache les images téléchargées. Ce module peut être représenté comme indiqué ci-dessous -

const Cache = require("tns-core-modules/ui/image-cache").Cache;

connectivité

Ce module permet de recevoir les informations de connexion du réseau connecté. Il peut être représenté par -

const connectivityModule = require("tns-core-modules/connectivity");

Modules de fonctionnalité

Les modules de fonctionnalité comprennent de nombreux modules spécifiques au système / à la plate-forme. Certains des modules importants sont les suivants -

platform- Utilisé pour afficher les informations sur votre appareil. Il peut être défini comme indiqué ci-dessous -

const platformModule = require("tns-core-modules/platform");

fps-meter- Utilisé pour capturer des images par seconde. Il peut être défini comme indiqué ci-dessous -

const fpsMeter = require("tns-core-modules/fps-meter");

file-system- Utilisé pour fonctionner avec le système de fichiers de votre appareil. Il est défini ci-dessous -

const fileSystemModule = require("tns-core-modules/file-system");

ui/gestures - Utilisé pour travailler avec les gestes de l'interface utilisateur.

Module d'interface utilisateur

Le module d'interface utilisateur comprend le composant d'interface utilisateur et ses fonctionnalités associées. Certains des modules d'interface utilisateur importants sont les suivants:

  • frame

  • page

  • color

  • text/formatted-string

  • xml

  • styling

  • animation

Le package npm est utilisé pour ajouter des fonctionnalités natives. En utilisant ce package, nous pouvons installer ou rechercher ou supprimer des plugins. Cette section explique en détail les plugins.

Commandes

add - Il est utilisé pour installer le plugin.

update - Met à jour le plugin spécifié et modifie ses dépendances.

remove - Supprime le plugin.

build - Il est utilisé pour créer un plugin pour des projets iOS ou Android.

create - Crée un plugin pour votre projet.

Ajout de plug-in

La syntaxe ci-dessous est utilisée pour ajouter un nouveau plugin -

tns plugin add <plugin-name>

Par exemple, si vous souhaitez ajouter nativescript-barcodescanner, vous pouvez utiliser le code suivant -

tns plugin add nativescript-barcodescanner

Vous pouvez voir la réponse suivante -

+ [email protected] 
added 1 package from 1 contributor and audited 11704 packages in 8.76s

Vous pouvez également utiliser le module npm pour ajouter le plugin ci-dessus -

npm install nativescript-barcodescanner

Maintenant, NativeScript CLI télécharge le plugin à partir de npm et l'ajoute dans votre dossier node_modules.

Si vous souhaitez ajouter le plugin directement à votre package.json et résolvez tous les problèmes de dépendance, vous pouvez utiliser la commande ci-dessous au lieu de la précédente -

npm i nativescript-barcodescanner

Si vous souhaitez installer des dépendances de développeur pendant le développement, utilisez le code ci-dessous -

npm i tns-platform-declarations --save-dev

Ici,

tns-platform-declarations est une dépendance de développeur requise uniquement pour intelliSense pendant le processus de développement.

Importer des plugins

Maintenant, nous avons installé nativescript-barcodescanner plugin. Laissez-nous ajouter à l'intérieur de votre projet en utilisant la commande ci-dessous -

const maps = require("nativescript-barcodescanner"); 
maps.requestPermissions();

Mise à jour des plugins

Cette méthode est utilisée pour mettre à jour un plugin spécifié afin qu'il désinstalle le précédent et installe la nouvelle version et modifie ses dépendances. Il est défini ci-dessous -

tns plugin update <Plugin name version>

Suppression du plug-in

Si vous souhaitez supprimer le plugin, s'il n'est pas nécessaire, vous pouvez utiliser la syntaxe ci-dessous -

tns plugin remove <plugin-name>

Par exemple, si vous souhaitez supprimer le nativescript-google-maps-sdk installé ci-dessus, utilisez la commande ci-dessous -

tns plugin remove nativescript-barcodescanner

Vous pouvez voir la réponse suivante -

Successfully removed plugin nativescript-barcodescanner

Création de plugins

Il est utilisé pour créer les fichiers de projet spécifiques à Android du plugin situés dans les plates-formes / android. Construisons le pugin nativescript-barcodescanner en utilisant la commande ci-dessous -

tns plugin build nativescript-barcodescanner

Créer des plugins

Les plugins NativeScript sont de simples modules JavaScript. Il est défini dans le fichier src \ package.json de votre application. Ce module est utilisé pour créer un nouveau projet pour le développement de plugins NativeScript. Il est défini ci-dessous -

tns plugin create <Plugin Repository Name> [--path <Directory>]

Cette section explique la présentation de l'accès aux API natives à l'aide de JavaScript.

Triage

Le NativeScript Runtime fournit une conversion de type implicite pour les plates-formes Android et iOS. Ce concept est connu sous le nom de marshalling. Par exemple, la palette NativeScript-iOS peut convertir implicitement les types de données JavaScript et Objective-C de la même manière, Java / Kotlin peut facilement être mappé aux types et valeurs de projet JavaScript. Comprenons comment effectuer brièvement le marshalling dans chaque type un par un.

Valeurs numériques

Nous pouvons facilement convertir les types de données numériques iOS et Android en nombres JavaScript. La conversion numérique simple pour iOS en JavaScript est définie ci-dessous -

console.log(`max(7,9) = ${max(7,9)}`);

Ici,

La fonction native max () est convertie en nombre JavaScript.

Environnement Android

Java prend en charge différents types numériques tels que byte, short, int, float, double et long. JavaScript n'a que le type de nombre.

Considérez une classe Java simple ci-dessous -

class Demo extends java.lang.Object {
   public int maxMethod(int a,int b) {
      if(a>b) {
         return a;
      } else {
         return b;
      }
   }
}

Ici,

Le code ci-dessus contient deux arguments entiers. Nous pouvons appeler l'objet de code ci-dessus en utilisant JavaScript comme indiqué ci-dessous -

//Create an instance for Demo class 
var obj = new Demo(); 

//implicit integer conversion for calling the above method 
obj.maxMethod(7,9);

Cordes

Les chaînes Android sont définies dans java.lang.string et les chaînes iOS sont définies dans NSSring. Voyons comment effectuer le marshalling sur les deux plates-formes.

Android

Les chaînes sont immuables mais les tampons String prennent en charge les chaînes mutables.

Le code ci-dessous est un exemple de mappage simple -

//Create android label widget 
var label = new android.widget.Label(); 

//Create JavaScript string 
var str = "Label1";  

//Convert JavaScript string into java label.setText(str); 
// text is converted to java.lang.String

La classe booléenne est définie dans java.lang.Boolean. Cette classe encapsule une valeur booléenne dans un objet. Nous pouvons facilement convertir un booléen en String et vice-versa. Un exemple simple est défini comme indiqué ci-dessous -

//create java string 
let data = new java.lang.String('NativeScript'); 

//map java String to JavaScript string, 
let result = data.startsWith('N'); 

//return result 
console.log(result);// true

environnement iOS

La classe NSString est immuable mais sa sous-classe NSMutableString est immuable. Cette classe contient une collection de méthodes pour travailler avec des chaînes. Il est déclaré comme ci-dessous -

class NSString : NSObject

Considérez une simple déclaration objective-c comme indiqué ci-dessous -

NSString *str = @"nativescript"; 
//convert the string to uppercase
NSString *str1; 
str1 = [str uppercaseString]; 
NSLog(@"Uppercase String : %@\n", str1 );

Les NSStrings peuvent facilement être mappées à des chaînes JavaScript.

Tableau

Cette section explique comment effectuer le marshalling dans les tableaux. Prenons d'abord un exemple d'environnement iOS.

Déclaration Array

class NSArray : NSObject

Ici,

NSArray est utilisé pour gérer une collection ordonnée d'objets appelés tableaux. Il est utilisé pour créer un tableau statique. Sa sous-classeNSMutableArray est utilisé pour créer des tableaux dynamiques.

Considérez que les objets NSArray peuvent être créés à l'aide de littéraux de tableau comme indiqué ci-dessous -

let array: NSArray = ["React","Vue","TypeScript"]

Maintenant, nous pouvons mapper ce tableau en JavaScript comme indiqué ci-dessous -

//create native array 
let nsArr = NSArray.arrayWithArray("React","Vue","TypeScript"]); 

//create simple javascript array 
let jsArr = ["Hello,World","NativeScript"]; 

//Now compare the two arrays, 
let compare = nsArr.isEqual(jsArr); 
console.log(comapre);

Cela renverra la sortie comme fausse.

Déclaration de tableau Android

Les tableaux Java sont définis dans java.util.Arrays. Cette classe contient diverses méthodes pour manipuler les tableaux. Un exemple est montré ci-dessous -

//javascript array 
let data = [12,45,23,56,34,78,50]; 

//create java array 
let result = ns.example.Math.maxElement(data);
console.log(result);

Classes et objets

Les classes et les objets sont des concepts de base de la programmation orientée objet. La classe est un prototype défini par l'utilisateur. L'objet est une instance de classe. La classe représente l'ensemble des propriétés ou méthodes communes à tous les objets d'un même type. Laissez-nous comprendre les classes et les objets natifs pour les deux environnements de développement mobile.

Environnement Android

Les classes Java et Kotlin ont des identificateurs uniques désignés par le nom complet du package.

Par exemple,

android.view.View- Il s'agit d'une classe d'interface utilisateur de base pour la disposition de l'écran et l'interaction avec l'utilisateur. Nous pouvons accéder à cette classe en JavaScript comme indiqué ci-dessous -

const View = android.view.View;

Tout d'abord, nous importons la classe en utilisant l'instruction ci-dessous -

import android.view.View;

Ensuite, créez une classe comme indiqué ci-dessous -

public class MyClass {
   public static void staticMethod(context) {
      //create view instance
      android.view.View myview = new android.view.View(context);
   }
}

Dans la même classe ci-dessus, nous pouvons accéder à la fonction JavaScript en utilisant le code ci-dessous -

const myview = new android.view.View(context);

De même, nous pouvons accéder aux interfaces, aux constantes et aux énumérations dans les packages java.lang.

Environnement iOS

Les classes Objective-C sont définies dans deux sections @interface et @implementation. La définition de classe commence par le mot-clé@interface suivi du interface(class)Nom. En Objective-C, toutes les classes sont dérivées de la classe de base appelée NSObject.

C'est la superclasse de toutes les classes Objective-C. La classe Simple Circle est définie comme indiqué ci-dessous -

@interface Circle:NSObject {
   //Instance variable
   int radius;
}
@end

Considérez une classe avec une méthode comme indiqué ci-dessous -

@interface MyClass : NSObject 
+ (void)baseStaticMethod; 
@end

Cette classe peut être convertie en javascript en utilisant le code ci-dessous -

function MyClass() { /* native call */ }; 
Object.setPrototypeOf(MyClass, NSObject); 
BaseClass.baseStaticMethod = function () { /* native call */ };

JavaScript instanceofL'opérateur est utilisé pour vérifier si un objet hérite d'une classe donnée. Cela peut être défini comme -

var obj = MyClass.alloc().init(); // object creation 
console.log(obj instanceof NSObject); //return true

Ici,

Les instances Objective-C sont créées à l'aide des méthodes alloc, init ou new. Dans l'exemple ci-dessus, nous pouvons facilement créer une initialisation d'objet en utilisant la nouvelle méthode comme ci-dessous -

var obj = MyClass.new();

De même, vous pouvez accéder aux méthodes et propriétés statiques.

Créer et publier votre application rend votre application Android accessible à tous les utilisateurs. Google Play est une plate-forme de publication robuste. Il vous aide à publier et à distribuer vos applications Android à tous les utilisateurs du monde entier. Ce chapitre explique comment publier votre application native sur Google Play.

Assistant NativeScript

SideKick est un client GUI et prend en charge tous les types d'OS. Il simplifie le processus CLI NativeScript et aide à créer une application mobile.

Publiez votre application depuis Sidekick sur la console Google Play

Le téléchargement et l'installation de sidekick dépendent de votre système d'exploitation. Suivez les étapes ci-dessous pour exécuter votre application dans Sidekick.

Step 1: Launch Sidekick

Lançons Sidekick. Cela ressemble à l'image ci-dessous -

Step 2: Build your device

Maintenant, ouvrez votre application à partir de votre appareil et sélectionnez l'option de construction dans la barre d'outils et sélectionnez Android. Vous obtiendrez une réponse similaire à l'image ci-dessous -

Step 3: Properties

Cliquez sur l'onglet Propriétés et ajoutez votre configuration Android. L'écran ressemble à celui ci-dessous -

Step 4: Plugins

Sidekick vous aide à trouver les plugins dont vous dépendez pour votre application. Cliquez sur l'onglet plugins et il listera les éléments suivants -

Step 5: Android Certificates

Cliquez sur l'icône de la roue dentée d'Android et choisissez l'option de navigation, puis sélectionnez un certificat stocké sur votre système de fichiers. Il est montré ci-dessous -

Après avoir sélectionné cela, fermez la boîte de dialogue.

Step 6: Build your application

Enfin, cliquez sur l'option de construction locale du type de construction et sélectionnez l'option de publication dans la configuration. Après cela, créez votre application.

Step 7: Application package

Une fois la construction terminée, il générera un chemin et apkfichier. Enregistrez l'emplacement du package d'application. Ce fichier apk est utilisé pour le télécharger sur le Google Play Store.

Step 8: Publish in Google Play

Sélectionnez l'option de publication dans la barre d'outils et sélectionnez Google Play. Ensuite, ajoutez la boîte de dialogue Gérer les certificats Android pour Google Play Store. Il est montré ci-dessous -

Après cela, sélectionnez le type de construction et fournissez la clé JSON du compte de service, puis sélectionnez les pistes alpha, bêta ou de production, puis cliquez sur télécharger.

Publiez votre application sur Google Play

Pour publier votre application dans la console Google Play, vous devez remplir les conditions préalables suivantes.

Conditions préalables

  • Vous devez être inscrit sur Google Play

  • Vous disposez d'une identité de signature de code auto-signée Google Play valide

Procédure de publication de votre application

Les étapes ci-dessous sont utiles pour comprendre comment publier votre application sur Google Play Store.

Step 1: Login Google Play console

Ouvrez la console Google Play et connectez-vous avec votre compte.

Step 2: Create an app

Accédez à l'onglet Toutes les applications, cliquez sur Créer une application et créez une nouvelle application. Maintenant, ajoutez la langue par défaut, le titre de l'application enfin cliquez sur Continuer pour aller plus loin.

Step 3: Fill required fields

Passez à l'onglet de la fiche Google Play Store et remplissez les champs obligatoires, puis complétez les éléments nécessaires et enregistrez toutes les modifications.

Step 4: Price and distribution

Accédez à l'onglet Prix et distribution, complétez tous les paramètres et enregistrez toutes les modifications.

Step 5: Release your app

Choisissez l'onglet Versions de l'application et sélectionnez Alpha, Bêta. Il est utilisé pour tester votre application. Et, sélectionnez Pistes de production. Il est utilisé pour publier votre application sur Google Play. Enfin, ajoutez le package d'application (apk).

Step 6: Review your app

Ceci est votre dernière étape. Dans l'examen, vérifiez s'il y a des problèmes. Si aucun problème, confirmez le déploiement pour publier votre application.

Ce chapitre explique comment publier votre application native dans l'App Store. Suivez les étapes ci-dessous pour publier votre application.

Conditions préalables

Pour ce faire, vous devez avoir les conditions préalables suivantes -

  • Certificat de distribution

  • Profil d'approvisionnement de distribution

  • ID de bundle enregistré dans le centre de développement iOS

  • Enregistrement d'application dans iTunes Connect

Étapes pour publier votre application

Voici les étapes pour publier votre application -

Étape 1: Ouvrez NativeScript Sidekick

Lancez NativeScript Sidekick et ouvrez votre application dans Sidekick.

Étape 2: sélectionnez publier

Accédez à la barre d'outils et sélectionnez l' option de publication dans la barre d'outils. Il est montré ci-dessous -

Maintenant, sélectionnez l'option Apple App Store. Cela ressemble à l'image ci-dessous -

Étape 3: Gérer la fourniture et les certificats iOS

Cliquez sur l'icône de la roue dentée de l'App Store d'Apple, choisissez l'option de navigation et ajoutez les détails.

Étape 4: Créez votre application

Ensuite, cliquez sur l'option de création et créez votre application et attendez que le processus se termine.

Étape 5: Fournissez les informations d'identification

Ceci est votre dernière étape. Spécifiez le nom d'utilisateur et le mot de passe Apple dans votre compte, cliquez sur télécharger et vérifiez le message de confirmation. Si vous souhaitez soumettre votre application pour examen, accédez à iTunes Connect et soumettez-la.

Les tests sont une phase très importante du cycle de vie de développement d'une application. Il garantit une qualité d'application. Il nécessite une planification et une exécution minutieuses. C'est également la phase de développement qui prend le plus de temps. Le framework NativeScript fournit un support étendu pour le test automatisé d'une application.

Types de tests

En règle générale, trois types de processus de test sont disponibles pour tester une application. Ils sont les suivants -

Test unitaire

Le test unitaire est la méthode la plus simple pour tester une application. Elle repose sur la vérification de l'exactitude d'un morceau de code (une fonction, en général) ou d'une méthode d'une classe. Mais, cela ne reflète pas l'environnement réel et par la suite. C'est la moindre des options pour trouver les bogues.

Généralement, NativeScript utilise Jasmine, Mocha avec les frameworks de tests unitaires Chai et QUnit.

Pour ce faire, vous devez d'abord configurer dans votre projet à l'aide de la commande ci-dessous -

tns test init

Maintenant, vous obtenez la réponse suivante -

? Select testing framework: (Use arrow keys) 
> jasmine 
   mocha 
   qunit

Maintenant, sélectionnez jasmine cadre et votre écran ressemble à ceci -

? Select testing framework: jasmine 
+ [email protected] 
added 90 packages from 432 contributors and audited 11944 packages in 8.753s 

+ [email protected] 
added 2 packages from 1 contributor and audited 11946 packages in 7.299s 

> [email protected] postinstall 
/Users/workspace/NativeScript/NativeApp/node_modules/core-js 

> node -e "try{require('./postinstall')}catch(e){}" 
Thank you for using core-js ( https://github.com/zloirock/core-js ) for 
polyfilling JavaScript standard library! 
The project needs your help! Please consider supporting of core-js on Open 
Collective or Patreon:

> https://opencollective.com/core-js 
> https://www.patreon.com/zloirock 
Also, the author of core-js ( https://github.com/zloirock ) is looking for a 
good job -) 
npm WARN [email protected] requires a peer of webpack@^2.0.0 
|| ^3.0.0 but none is installed. You must install peer dependencies yourself. 

+ [email protected] 
added 19 packages from 52 contributors and audited 12012 packages in 9.368s 

+ [email protected] 
added 2 packages from 35 contributors and audited 12014 packages in 6.925s 

+ [email protected] 
updated 1 package and audited 12014 packages in 7.328s 
+ @types/[email protected] 

> [email protected] postinstall /Users/deiva/workspace/NativeScript/NativeApp/node_modules/nativescript-unit
-test-runner 

> node postinstall.js 
+ [email protected] 

added 1 package from 1 contributor and audited 12032 packages in 7.14s 
Successfully installed plugin nativescript-unit-test-runner. 

Example test file created in src/tests 
Run your tests using the "$ tns test <platform>" command.

Maintenant, le fichier de test est créé dans src \ tests \ example.ts.

Créez vos tests

Ajoutons un simple test dans le fichier example.ts comme indiqué ci-dessous -

describe("NativeApp test:", function() { 
   it("Check counter.", function() { 
      expect(mainViewModel.createViewModel().counter).toEqual(10); 
   }); 
   it("Check message.", function () { 
      expect(mainViewModel.createViewModel().message).toBe("10 taps left"); 
   }); 
});

Ici,

Tout d'abord, vérifiez si le compteur est égal à 10 et vérifiez si le message reste 10 taps.

Exécutons le test à l'étape suivante.

Exécutez vos tests

Maintenant, exécutez le test sur un appareil connecté Android ou iOS à l'aide de la commande ci-dessous -

tns test android

Cela renverra le statut suivant -

? To continue, choose one of the following options: (Use arrow keys) 
> Configure for Cloud Builds 
   Configure for Local Builds 
   Configure for Both Local and Cloud Builds 
   Skip Step and Configure Manually

Ensuite, choisissez l'option ci-dessous -

? To continue, choose one of the following options: Configure for Local Builds 
Running the setup script to try and automatically configure your environment. 
These scripts require sudo permissions 
.....

Pour exécuter votre suite de tests dans le simulateur Android, exécutez la commande suivante -

tns test android --emulator

Désormais, le serveur karma prépare les builds et déploie votre projet.

Test de bout en bout (E2E)

Les tests unitaires sont des processus petits, simples et rapides, tandis que, lors de la phase de test E2E, plusieurs composants sont impliqués et fonctionnent ensemble, ce qui couvre les flux dans l'application. Cela n'a pas pu être réalisé par des tests unitaires et d'intégration.

NativeScript Appiumplugin est utilisé pour effectuer des tests d'automatisation E2E. Eh bien, Appium est un cadre de test open source pour les applications mobiles. Pour ajouter ce framework à votre projet, vous devez disposer de la dernière version de XCode ou du SDK Android supérieur à 25.3.0.

Installez Appium

Installons Appium globalement en utilisant le module npm -

npm install -g appium

Maintenant, vous pouvez voir la réponse suivante -

npm install -g appium 
/Users/.npm-global/bin/authorize-ios -> 
/Users/.npm-global/lib/node_modules/ appium/node_modules/.bin/authorize-ios 

> [email protected] install 
/Users/.npm-global/lib/node_modules/ appium/node_modules/appium-windows-driver

> node install-npm.js 
Not installing WinAppDriver since did not detect a Windows system 

> [email protected] postinstall /Users/.npm-
global/lib/node_modules/appium/node_modules/core-js 

> node -e "try{require('./postinstall')}catch(e){}" 
Thank you for using core-js ( https://github.com/zloirock/core-js ) for 
polyfilling JavaScript 
standard library! 
The project needs your help! Please consider supporting of core-js on Open Collective or Patreon: 

> https://opencollective.com/core-js 
> https://www.patreon.com/zloirock 
Also, the author of core-js ( https://github.com/zloirock ) 
is looking for a good job -) 

> [email protected] postinstall/Users/.npm-
global/lib/node_modules/appium/node_modules 
/appium-chromedriver 

> node install-npm.js 
............................................ 
............................................. 
+ [email protected] 
added 671 packages from 487 contributors in 28.889s

Ajouter un plugin

Ajoutons nativescript-dev-appium plugin en tant que devDependency de votre projet en utilisant la commande ci-dessous -

$ npm install -D nativescript-dev-appium

Après avoir exécuté ceci, choisissez mocha framework et vous obtiendrez une réponse similaire à celle-ci -

> node ./postinstall.js 
? What kind of project do you use
? javascript ? Which testing framework do you prefer? mocha 
+ [email protected]

Désormais, les fichiers sont stockés dans votre dossier de projet.

Construisez votre appareil

Construisons un appareil Android en utilisant la commande ci-dessous -

tns build android

La commande ci-dessus exécutera les tests devraient spécifier les capacités ciblées. Si vous avez un appareil iOS, vous pouvez créer en utilisantiOS dispositif.

Exécuter le test

Maintenant, nous avons configuré l'appareil. Lançons notre test en utilisant la commande ci-dessous -

npm run e2e -- --runType <capability-name>

Ici,

Le nom de capacité est défini dans votre application e2e/config/appium.capabilities.json.

Production

NativeScript - Conclusion

NativeScript est une excellente application mobile permettant aux développeurs Web de tester leur application de manière très simple et sans effort supplémentaire. Les développeurs peuvent développer en toute confiance une application élégante et réussie sans aucun problème dans un court laps de temps.