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="" 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
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.