NativeScript - Guía rápida

Generalmente, desarrollar una aplicación móvil es una tarea compleja y desafiante. Hay muchos marcos disponibles para desarrollar una aplicación móvil. Android proporciona un marco nativo basado en el lenguaje Java e iOS proporciona un marco nativo basado en el lenguaje Objective-C / Shift. Sin embargo, para desarrollar una aplicación que admita ambos sistemas operativos, necesitamos codificar en dos lenguajes diferentes usando dos marcos diferentes.

Para superar esta complejidad, los marcos móviles admiten esta función. La razón principal detrás de usar un marco híbrido o multiplataforma es más fácil de mantener una base de código única. Algunos de los marcos populares son NativeScript, Apache Cordova, Xamarin, etc.

Descripción general de los marcos de JavaScript

JavaScript es un lenguaje de paradigmas múltiples. Admite programación funcional, programación orientada a objetos y basada en prototipos. JavaScript se utilizó inicialmente para el lado del cliente. Hoy en día, JavaScript también se utiliza como lenguaje de programación del lado del servidor. Los marcos de JavaScript son un tipo de herramienta que hace que trabajar con JavaScript sea más fácil y fluido.

Con este marco, los programadores pueden codificar fácilmente la aplicación como un dispositivo sensible. La capacidad de respuesta es una de las razones por las que este marco se está volviendo muy popular.

Echemos un vistazo a algunos de los marcos JS populares:

Angular

Uno de los frameworks JavaScript más poderosos, eficientes y de código abierto es Angular. Podemos crear aplicaciones móviles y de escritorio. Google usa este marco. Se utiliza para desarrollar una aplicación de página única (SPA).

Vue.js

VueJS es un marco de JavaScript progresivo que se utiliza para desarrollar interfaces web interactivas. Es uno de los marcos famosos que se utilizan para simplificar el desarrollo web. Se puede integrar fácilmente en grandes proyectos para el desarrollo front-end sin ningún problema. Su modo de integración dual es una de las características más atractivas para la creación de aplicaciones de una sola página o SPA de alta gama.

Reaccionar

ReactJS es una biblioteca de JavaScript que se utiliza para crear componentes de IU reutilizables. Está desarrollado por Facebook. Actualmente es una de las bibliotecas de JavaScript más populares y tiene una base sólida y una gran comunidad detrás de ella.

Node.js

Node.js es un entorno de ejecución multiplataforma de código abierto para desarrollar aplicaciones de red y del lado del servidor. Está construido sobre el motor JavaScript de Google Chrome (motor V8). Las aplicaciones de Node.js están escritas en JavaScript y se pueden ejecutar en OS X, Microsoft Windows y Linux. Proporciona una rica biblioteca de varios módulos de JavaScript que simplifica el desarrollo de aplicaciones web.

Descripción general de NativeScript

NativeScript es un marco de código abierto utilizado para crear aplicaciones móviles nativas de iOS y Android. Es un marco compilado JIT. El código NativeScript se ejecuta en una máquina virtual JS. Utiliza el tiempo de ejecución del motor V8 para las plataformas Android e iOS. NativeScript utiliza XML, JS y CSS para el desarrollo. Tiene una WebIDE conocida como PlayGround. Este PlayGround admite una interfaz de trabajo fácil, proyectos fáciles de administrar, recarga en caliente y depuración en dispositivos.

NativeScript permite a los desarrolladores crear aplicaciones nativas multiplataforma de manera rápida y eficiente y ahorrar en los costos de desarrollo, pruebas y capacitación. Por lo tanto, las aplicaciones nativas seguirán siendo ricas y sólidas durante los próximos años para hacerlas mejores y más fáciles de usar.

Caracteristicas

NativeScript tiene un vibrante apoyo de la comunidad. Algunas de las características más destacadas de NativeScript enumeradas a continuación:

  • Extensible

  • Reemplazo de módulo caliente

  • Fácil de configurar

  • Podemos crear animaciones, gráficos, cuadros y listas enriquecidos

  • Los desarrolladores pueden usar cualquier vista como raíz de una aplicación

  • Codificación perezosa

Beneficios

NativeScript ayuda a las empresas de pequeña o gran escala a crear aplicaciones móviles multiplataforma. Algunos de los beneficios clave son:

  • Los desarrolladores pueden reutilizar el código y las herramientas existentes

  • Fácil de modificar, solucionar problemas y actualizar versiones más recientes

  • La experiencia de desarrollo es buena, por lo que no tenemos que perder tiempo para aprender nuevas herramientas.

  • API específicas de plataforma de JavaScript, eliminando la necesidad de aprender los complementos de Cordova

  • Facilite la autenticación con diferentes proveedores de inicio de sesión

Esta sección explica cómo instalar NativeScript en su máquina.

Prerrequisitos

Antes de pasar a la instalación, necesitamos los siguientes requisitos previos:

  • Node.js

  • Android

  • iOS

Verificar Node.js

Node.js es un motor en tiempo de ejecución de JavaScript construido sobre el motor interno de JavaScript de Google Chrome, v8. NativeScript usa Node.js ampliamente para varios propósitos, como crear la aplicación de plantilla de inicio, compilar la aplicación, etc. Es obligatorio tener Node.js en su máquina.

Con suerte, ha instalado Node.js en su máquina. Si no está instalado, visite el enlace,https://nodejs.org/ y descargue el último paquete LTS e instálelo.

Para verificar si Node.js está instalado correctamente, escriba el siguiente comando en su terminal:

node --version

Podías ver la versión. A partir de ahora, la versión estable actual "LTS" del nodo es 12.14.0.

Configuración CLI

NativeScript CLI es una aplicación basada en terminal / línea de comandos y le permite crear y desarrollar aplicaciones NativeScript. El administrador de paquetes npm de Node.js se usa para instalar la CLI de NativeScript en su máquina.

Utilice el siguiente comando para instalar NativeScript CLI:

npm install -g nativescript

Después de ejecutar este comando, pudimos ver el siguiente resultado:

setupcli

Hemos instalado la última CLI de NativeScript, tns en nuestro sistema. Ahora, escriba el siguiente comando en su terminal:

tns

Esto mostrará una guía de inicio rápido. Podrías ver el siguiente resultado:

cli

Podemos usar tns para crear y desarrollar aplicaciones incluso sin ninguna configuración adicional. Pero no pudimos implementar la aplicación en un dispositivo real. En su lugar, podemos ejecutar la aplicación usando la aplicación NativeScript PlayGround iOS / Android. Lo comprobaremos en los próximos capítulos.

Instalación de la aplicación de juegos NativeScript

Vaya a su tienda de aplicaciones iOS o Google Play Store y busque la aplicación NativeScript Playground. Una vez que la aplicación aparece en el resultado de la búsqueda, haga clic en la opción de instalación. Instalará la aplicación NativeScript Playground en nuestro dispositivo.

La aplicación NativeScript Playground será útil para probar sus aplicaciones en dispositivos Android o iOS sin implementar la aplicación en el dispositivo o emulador real. Esto reducirá el tiempo para desarrollar la aplicación y una manera fácil de poner en marcha el desarrollo de nuestra aplicación móvil.

Configuración de Android e iOS

En este capítulo, aprendamos cómo configurar el sistema para crear y ejecutar aplicaciones de iOS y Android, ya sea en un emulador o en un dispositivo real.

Paso 1: dependencia de Windows

Ejecute el siguiente comando en el símbolo del sistema de Windows y ejecútelo como administrador:

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

Después de este comando, los scripts que se están descargando, instale las dependencias y configúrelo.

Paso 2: dependencia de macOS

Para instalar en macOS, debe asegurarse de que Xcode esté instalado o no. Xcode es obligatorio para NativeScript. Si Xcode no está instalado, visite el siguiente enlacehttps://developer.apple.com/xcode/y descargar; luego instálelo.

Ahora ejecute el siguiente comando en su terminal:

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

Después de ejecutar el comando anterior, el script instalará las dependencias para el desarrollo de iOS y Android. Una vez hecho esto, cierra y reinicia tu terminal.

Paso 3: dependencia de Android

Con suerte, ha configurado los siguientes requisitos previos:

  • JDK 8 o superior

  • SDK de Android

  • Repositorio de soporte de Android

  • Repositorio de Google

  • Herramientas de compilación del SDK de Android 28.0.3 o superior

  • Estudio de Android

Si los requisitos previos anteriores no están configurados, visite el siguiente enlace https://developer.android.com/studio/instalarlo e instalarlo. Finalmente, agregue JAVA_HOME y ANDROID_HOME en sus variables de entorno.

Paso 4: verificar las dependencias

Ahora todo está hecho. Puede verificar la dependencia usando el siguiente comando:

tns doctor

Esto verificará toda la dependencia y resumirá el resultado de la siguiente manera:

√ 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 encuentra algún problema, corríjalo antes de continuar con el desarrollo de la aplicación.

NativeScript es un marco avanzado para crear aplicaciones móviles. Oculta la complejidad de la creación de aplicaciones móviles y expone una API bastante simple para crear aplicaciones móviles avanzadas y altamente optimizadas. NativeScript permite incluso a los desarrolladores de nivel de entrada crear fácilmente aplicaciones móviles tanto en Android como en iOS.

Entendamos la arquitectura del marco NativeScript en este capítulo.

Introducción

El concepto central del marco de NativeScript es permitir al desarrollador crear una aplicación móvil de estilo híbrido. La aplicación híbrida utiliza la API de navegador específica de la plataforma para alojar una aplicación web dentro de una aplicación móvil normal y proporciona acceso del sistema a la aplicación a través de la API de JavaScript.

NativeScript invierte mucho en JavaScript languagepara proporcionar un marco eficiente para los desarrolladores. Ya queJavaScriptes un estándar de facto para la programación del lado del cliente (desarrollo web) y todos los desarrolladores conocen bien el lenguaje JavaScript, lo que ayuda a los desarrolladores a entrar fácilmente en el marco de NativeScript. En el nivel bajo, NativeScript expone la API nativa a través de una colección de complementos de JavaScript llamadosNative plugins.

NativeScript se basa en los complementos nativos y proporciona muchos módulos JavaScript de alto nivel y fáciles de usar . Cada módulo tiene una funcionalidad específica como acceder a una cámara, diseñar una pantalla, etc. Todos estos módulos se pueden combinar de múltiples formas para diseñar una aplicación móvil compleja.

El siguiente diagrama muestra la descripción general de alto nivel del marco de NativeScript:

NativeScript Application - El marco de NativeScript permite al desarrollador usar una aplicación de estilo angular o una aplicación de estilo Vue.

JavaScript Modules - El marco de NativeScript proporciona un amplio conjunto de módulos JavaScript claramente categorizados como módulos de interfaz de usuario, módulos de aplicación, módulos principales, etc. Se puede acceder a todos los módulos por aplicación en cualquier momento para escribir cualquier nivel de aplicación compleja.

JavaScript plugins- El marco de NativeScript proporciona una gran colección de complementos de JavaScript para acceder a la funcionalidad relacionada con la plataforma. Los módulos utilizan los complementos de JavaScript para proporcionar una funcionalidad específica de la plataforma.

Native plugins- Los complementos nativos están escritos en un lenguaje específico de la plataforma para envolver la funcionalidad del sistema que luego será utilizada por el complemento de JavaScript.

Platform API - API proporcionada por los proveedores de la plataforma.

En resumen, la aplicación NativeScript está escrita y organizada mediante módulos. Los módulos están escritos en JavaScript puro y los módulos acceden a la funcionalidad relacionada con la plataforma (cuando sea necesario) a través de complementos y, finalmente, los complementos unen la API de la plataforma y la API de JavaScript.

Flujo de trabajo de una aplicación NativeScript

Como aprendimos anteriormente, la aplicación NativeScript se compone de módulos. Todos y cada uno de los módulos habilitan una función específica. Las dos categorías importantes de módulo para arrancar una aplicación NativeScript son las siguientes:

  • Módulos raíz

  • Módulos de página

Los módulos raíz y de página se pueden clasificar como módulos de aplicación. El módulo de la aplicación es el punto de entrada de la aplicación NativeScript. Inicia una página, permite al desarrollador crear una interfaz de usuario de la página y finalmente permite la ejecución de la lógica empresarial de la página. Un módulo de aplicación consta de los siguientes tres elementos:

  • Diseño de interfaz de usuario codificado en XML (por ejemplo, page.xml / page.component.html)

  • Estilos codificados en CSS (por ejemplo, page.css / page.component.css)

  • Lógica empresarial real del módulo en JavaScript (por ejemplo, page.js / page.component.ts)

NativeScript proporciona muchos componentes de interfaz de usuario (en el módulo de interfaz de usuario) para diseñar la página de la aplicación. El componente UI se puede representar en formato XML o HTML en una aplicación basada en Angular. El módulo de la aplicación utiliza el componente UI para diseñar la página y almacenar el diseño en XML separado, page.xml / page.component.html . El diseño se puede diseñar utilizando CSS estándar.

Los módulos de la aplicación almacenan el estilo del diseño en CSS separado, page.css / page.component.css. La funcionalidad de la página se puede realizar utilizando JavaScript / TypeScript, que tiene acceso completo al diseño y a las funciones de la plataforma. El módulo de la aplicación utiliza un archivo separado, page.js / page.component.ts para codificar la funcionalidad real de la página.

Módulos raíz

NativeScript gestiona la interfaz de usuario y la interacción del usuario a través de contenedores de UI. Cada contenedor de IU debe tener un módulo raíz y a través del cual el contenedor de IU administra la IU. La aplicación NativeScript tiene dos tipos de contenedores de IU:

Application Container- Cada aplicación NativeScript debe tener un contenedor de aplicación y se configurará mediante el método application.run (). Inicializa la interfaz de usuario de la aplicación.

Model View Container- NativeScript administra los cuadros de diálogo modales mediante el contenedor de vista de modelo. Una aplicación NativeScript puede tener cualquier número de contenedor de vista de modelo.

Cada módulo raíz debe tener solo un componente de interfaz de usuario como contenido. El componente de IU, a su vez, puede tener otros componentes de IU como hijos. NativeScript proporciona muchos componentes de IU como TabView, ScrollView, etc., con función secundaria. Podemos usarlos como componente raíz de la interfaz de usuario. Una excepción es Frame , que no tiene opción secundaria pero se puede usar como componente raíz. Frame ofrece opciones para cargar módulos de página y opciones para navegar a otros módulos de página también.

Módulos de página

En NativeScript, todas y cada una de las páginas son básicamente un módulo de página . El módulo de página está diseñado utilizando el rico conjunto de componentes de interfaz de usuario proporcionados por NativeScript. Los módulos de página se cargan en la aplicación a través del componente Frame (usando su atributo defaultPage o usando el método navigate ()), que a su vez se cargan usando Módulos raíz , que nuevamente se cargan usando application.run () mientras se inicia la aplicación.

El flujo de trabajo de la aplicación se puede representar como en el siguiente diagrama:

El diagrama anterior se explica en detalle en los siguientes pasos:

  • La aplicación NativeScript inicia y llama al método application.run ().

  • application.run () carga un módulo raíz .

  • El módulo raíz está diseñado utilizando cualquiera de los componentes de la interfaz de usuario como se especifica a continuación:

    • Frame

    • TabView

    • SideDrawer

    • Cualquier vista de diseño

  • El componente Frame carga la página especificada (módulo de página) y se renderiza. Otros componentes de la interfaz de usuario se procesarán como se especifica en el módulo raíz . Otro componente de la interfaz de usuario también tiene la opción de cargar módulos de página como contenido principal.

Flujo de trabajo de la aplicación NativeScript basada en Angular

Como aprendimos anteriormente, el marco de NativeScript proporciona múltiples metodologías para atender a diferentes categorías de desarrolladores. Las metodologías compatibles con NativeScript son las siguientes:

  • NativeScript Core - Concepto básico o central de NativeScript Framework

  • Angular + NativeScript - Metodología basada en angular

  • Vuejs + NativeScript - Metodología basada en Vue.js

Aprendamos cómo se incorpora el marco Angular en el marco de NativeScript.

Paso 1

NativeScript proporciona un objeto (platformNativeScriptDynamic) para iniciar la aplicación Angular. platformNativeScriptDynamic tiene un método, bootstrapModule, que se utiliza para iniciar la aplicación.

La sintaxis para arrancar la aplicación usando el marco Angular es la siguiente:

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

Aquí,

AppModule es nuestro módulo raíz.

Paso 2

Una implementación simple (debajo del código especificado) del módulo de la aplicación.

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 { }

Aquí,

AppModuleinicia la aplicación cargando el componente AppComponent. Los componentes angulares son similares a las páginas y se utilizan tanto para el diseño como para la lógica de programación.

Una implementación simple de AppComponent (app.component.ts) y su lógica de presentación (app.component.css) es la siguiente:

app.component.ts

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

Aquí,

templateUrl hace referencia al diseño del componente.

app.component.html

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

Aquí,

page-router-outlet es el lugar donde se adjunta la aplicación Angular.

En resumen, el framework Angular está compuesto por módulos similares al framework NativeScript con ligeras diferencias. Cada módulo en Angular tendrá un componente Angular y un archivo de configuración del enrutador (page-routing.mocdule.ts). El enrutador se configura por módulo y se encarga de la navegación. Los componentes angulares son análogos a las páginas en el núcleo de NativeSctipt.

Cada componente tendrá un diseño de interfaz de usuario (page.component.html), una hoja de estilo (page.component.css) y un archivo de código JavaScript / TypeScript (page.component.ts).

Creemos una aplicación básica básica para comprender el flujo de trabajo de la aplicación NativeScript.

Creando la Aplicación

Aprendamos cómo crear una aplicación simple usando NativeScript CLI, tns. tns proporciona un comando create to used para crear un nuevo proyecto en NativeScript.

La sintaxis básica para crear una nueva aplicación es la siguiente:

tns create <projectname> --template <template_name>

Dónde,

  • Projectname es el nombre del proyecto.

  • template_namees la plantilla de proyecto. NativeScript proporciona muchas plantillas de inicio para crear diferentes tipos de aplicaciones. Utilice una plantilla basada en Angular.

Creemos un nuevo directorio llamado NativeScriptSamples para trabajar en nuestra nueva aplicación. Ahora, abra una nueva terminal, luego muévase a nuestro directorio y escriba el siguiente comando:

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

Dónde, tns-template-blank-ng hace referencia a una aplicación móvil en blanco basada en AngularJS.

Salida

..... 
..... 
..... 
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

Ahora, se crea nuestra primera aplicación móvil, BlankNgApp .

Estructura de la aplicación

Entendamos la estructura de la aplicación NativeScript analizando nuestra primera aplicación BlankNgApp en este capítulo. La aplicación NativeScript está organizada en varias secciones y son las siguientes:

  • Sección de configuración

  • Módulos de nodo

  • Fuentes de Android

  • Fuentes de iOS

  • Código fuente de la aplicación

La estructura general de la aplicación es la siguiente:

│ 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

Entendamos cada sección de la aplicación y cómo nos ayuda a crear nuestra aplicación.

Sección de configuración

Todos los archivos en la raíz de la aplicación son archivos de configuración. El formato de los archivos de configuración está en formato JSON, lo que ayuda al desarrollador a comprender fácilmente los detalles de configuración. La aplicación NativeScript se basa en estos archivos para obtener toda la información de configuración disponible. Repasemos todos los archivos de configuración en esta sección.

package.json

Los archivos package.json establecen la identidad (id) de la aplicación y todos los módulos de los que depende la aplicación para su correcto funcionamiento. A continuación se muestra nuestro 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" 
}

Aquí,

Identity of the application (nativescript/id)- Establece la identificación de la aplicación como org.nativescript.BlankNgApp. Esta identificación se utiliza para publicar nuestra aplicación en Play Store o iTunes. Esta identificación será nuestro identificador de aplicación o nombre de paquete.

Dependencies (dependencies)- Especifica todos nuestros módulos de nodo dependientes. Dado que la implementación predeterminada de NativeScript depende de Angular Framework, se incluyen módulos angulares.

Development dependencies- Especifica todas las herramientas de las que depende la aplicación. Dado que estamos desarrollando nuestra aplicación en TypeScript, incluye mecanografiado como uno de los módulos dependientes.

angular.json - Información de configuración del marco angular.

nsconfig.json - Información de configuración del marco de NativeScript.

tsconfig.json, tsfmt.json & tsconfig.tns.json - Información de configuración del lenguaje TypeScript

webpack.config.js - Configuración de WebPack escrita en JavaScript.

Módulos de nodo

Como el proyecto NativeScript es un proyecto basado en nodos, almacena todas sus dependencias en la carpeta node_modules. Podemos usar npm (npm install) o tns para descargar e instalar toda la dependencia de la aplicación en node_moduels.

Código fuente de Android

NativeScript genera automáticamente el código fuente de Android y lo coloca en la carpeta App_Resources \ Android. Se utilizará para crear una aplicación de Android con el SDK de Android

código fuente de iOS

NativeScript genera automáticamente el código fuente de iOS y lo coloca en la carpeta App_Resources \ iOS. Se usará para crear una aplicación iOS usando iOS SDK y XCode

Código fuente de la aplicación

El código de la aplicación real se coloca en la carpeta src. Nuestra aplicación tiene los siguientes archivos en la carpeta 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

Entendamos el propósito de todos los archivos y cómo están organizados en esta sección:

Paso 1

main.ts: punto de entrada de la aplicación.

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

Aquí, hemos configurado AppModule como el módulo de arranque de la aplicación.

Paso 2

app.css: la hoja de estilo principal de la aplicación se muestra a continuación:

@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. */

Aquí,

app.css importa la hoja de estilo principal y la hoja de estilo de temas de color marrón del marco de NativeScript.

Paso 3

app \ app.module.ts: módulo raíz de la aplicación.

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 { }

Aquí,

AppModule se crea en base a NgModule y establece los componentes y módulos de la aplicación. Importa dos módulos NativeScriptModule y AppRoutingModule y un componente, AppComponent. También estableció AppComponent como el componente raíz de la aplicación.

Etapa 4

app.component.ts: componente raíz de la aplicación.

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

Aquí,

AppComponent establece la plantilla y la hoja de estilo del componente. La plantilla está diseñada en HMTL simple utilizando componentes de interfaz de usuario de NativeScript.

Paso 5

app-routing.module.ts: módulo de enrutamiento para 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 { }

Aquí,

AppRoutingModule usa NativeScriptRouterModule y establece las rutas de AppModule. Básicamente, redirige la ruta vacía a / home y señala / home a HomeModule.

Paso 6

app \ home \ home.module.ts: define un nuevo módulo, 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 { }

Aquí,

HomeModule importa dos módulos, HomeRoutingModule y NativeScriptCommonModule y un componente HomeComponent

Paso 7

app \ home \ home.component.ts: define el componente Inicio y se utiliza como página de inicio de la aplicación.

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. 
   } 
}

Aquí,

HomeComponent establece la plantilla y el selector del componente de inicio.

Paso 8

app \ home \ home-routing.module.ts: módulo de enrutamiento para HomeModule y se utiliza para definir el enrutamiento para el módulo de inicio.

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 { }

Aquí,

HomeRoutingModule establece la ruta vacía a HomeComponent.

Paso 9

app.component.html y home.component.html: se utilizan para diseñar la interfaz de usuario de la aplicación utilizando componentes de interfaz de usuario de NativeScript.

Ejecute su aplicación

Si desea ejecutar su aplicación sin usar ningún dispositivo, escriba el siguiente comando:

tns preview

Después de ejecutar este comando, esto generará un código QR para escanear y conectarse con su dispositivo.

Salida

QRCode

Ahora se genera el código QR y se conecta a PlayGround en el siguiente paso.

NativeScript PlayGround

Abra la aplicación NativeScript PlayGround en su dispositivo móvil iOS o Android y luego elija la opción Escanear código QR . Abrirá la cámara. Enfoque el código QR que se muestra en la consola. Esto escaneará el código QR. Escanear el código QR activará la compilación de la aplicación y luego sincronizará la aplicación con el dispositivo como se indica a continuación:

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.

Salida

Después de escanear, debería ver su BlankNgApp en su dispositivo. Se muestra a continuación:

Ejecute su aplicación en el dispositivo

Si desea probar el dispositivo conectado en su aplicación, puede verificarlo usando la siguiente sintaxis:

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

Después de eso, puede ejecutar su aplicación usando el siguiente comando:

tns run

El comando anterior se usa para crear sus aplicaciones localmente e instalarlas en dispositivos Android o iOS. Si desea ejecutar su aplicación en un simulador de Android, escriba el siguiente comando:

tns run android

Para dispositivos iOS, puede seguir el siguiente comando:

tns run ios

Esto inicializará la aplicación en un dispositivo Android / iOS. Discutiremos esto con más detalle en los próximos capítulos.

LiveSync

NativeScript proporciona sincronización en tiempo real de los cambios de la aplicación con la aplicación de vista previa. Permítanos abrir el proyecto usando cualquiera de sus editores favoritos (Visual Studio Code sería la opción ideal para una mejor visualización). Agreguemos algunos cambios en nuestro código y veamos cómo se detectarán en LiveSync.

Ahora abra el archivo app.css y tendrá el contenido a continuación:

@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. */

Aquí, la declaración de importación indica el esquema de color de nuestra aplicación. Cambiemos el esquema de color azul albrown esquema de color como se especifica a continuación -

@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. */

La aplicación en nuestro dispositivo se actualiza y debería ver una ActionBar de color marrón como se muestra a continuación:

Salida

A continuación se muestra la página de inicio de BlankNgApp - Tema marrón.

NativeScript proporciona una gran cantidad de plantillas listas para usar para crear aplicaciones en blanco simples pero completamente funcionales para aplicaciones complejas basadas en pestañas.

Usando plantilla

Como se aprendió anteriormente, se puede crear una nueva aplicación usando create subcomando del comando tns.

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

Aquí,

tns-template-name es el nombre de la plantilla.

Si desea crear una plantilla con una página y sin estilos personalizados usando JavaScript, use el siguiente comando:

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

La misma plantilla anterior se puede crear usando TypeScript de la siguiente manera:

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

Plantilla de navegación

La plantilla de navegación se utiliza para crear aplicaciones de moderadas a complejas. Viene con preconfiguradoSideDrawer componente con varias páginas. SideDrawerEl componente contiene una vista oculta para la interfaz de usuario de navegación o la configuración común. Utilice el siguiente comando para crear una aplicación basada en la navegación:

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

Plantilla de navegación de pestañas

La plantilla de navegación por pestañas se utiliza para crear aplicaciones basadas en pestañas. Viene con preconfiguradoTabViewcomponente con varias páginas. Utilice el siguiente comando para crear una aplicación basada en pestañas:

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

Plantilla de detalle maestro

La plantilla Master-Detail se utiliza para crear una aplicación basada en listas junto con una página de detalles para cada elemento de la lista.

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

Plantilla personalizada

Para crear una plantilla personalizada simple, necesitamos clonar plantillas en blanco. Como ya sabe, NativeScript es compatible con las plantillas JavaScript, TypeScript, Angular y Vue.js para que pueda elegir cualquier idioma y crear uno personalizado.

Por ejemplo, clone una plantilla simple y personalizada desde el repositorio de git usando el siguiente comando:

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

Ahora, creará la estructura de la aplicación móvil para que pueda hacer cualquier cambio y ejecutar su dispositivo Android / iOS. Esta estructura se basa en la lista de pautas. Veamos brevemente las pautas.

Estructura

Su plantilla personalizada debe cumplir con los siguientes requisitos:

  • No coloques tu código dentro de la carpeta raíz de tu aplicación.

  • Cree una carpeta separada y agregue un área de características adentro.

  • La página, los modelos de vista y el servicio deben colocarse en el área de características. Esto ayuda a crear un código limpio y ordenado.

  • Crear carpeta de la página y el lugar en el interior Ts, .xml, .scss / css, etc. , archivos.

package.json

Coloque el archivo package.json en la carpeta raíz de la plantilla de su aplicación. Proporcione un valor para la propiedad del nombre usando el formato -

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

Asigne un valor a la propiedad de la versión. Se define a continuación:

"version": "3.2.1",

Asigne un valor para la propiedad principal que especifique el punto de entrada principal a su aplicación. Se define a continuación:

"main": "app.js",

Asigne un valor a la propiedad de Android. Se define a continuación:

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

La propiedad del repositorio debe especificarse dentro de su código de la siguiente manera:

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

Estilo

Importe estilos y temas en la plantilla de su aplicación utilizando la siguiente sintaxis:

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

También podemos asignar un color de fondo personalizado usando el siguiente código:

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

NativeScript proporciona un gran conjunto de componentes de interfaz de usuario y se denominan "widgets". Cada widget realiza una tarea especial y viene con un conjunto de métodos. Comprendamos los widgets de NativeScript en detalle en esta sección.

Botón

El botón es un componente para ejecutar la acción del evento de toque. Cuando un usuario toca el botón, realiza las acciones correspondientes. Se define a continuación:

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

Agreguemos el botón en nuestra BlankNgApp como se muestra a continuación:

Paso 1

Abre el src\app\home\home.component.html. Esta es la página de diseño de la interfaz de usuario de nuestro componente de inicio.

Paso 2

Agregue un botón dentro del GirdLayoutcomponente. El código completo es el siguiente:

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

Salida

A continuación se muestra la salida del botón:

Paso 3

Podemos diseñar el botón usando CSS como se especifica a continuación:

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

Aquí, -primary La clase se usa para representar el botón principal.

Salida

A continuación se muestra la salida de ButtonPrimary -

Etapa 4

NativeScript proporciona una opción formateada para proporcionar iconos personalizados en el botón. El código de muestra es el siguiente:

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

Aquí,

& # xf099 especifica la ubicación del icono en la fuente, FontAwesome. Descargue la última fuente Font Awesome y coloque fontawesome-webfont.ttf en la carpeta src \ fonts.

Salida

A continuación se muestra la salida de ButtonPrimary -

Paso 5

El botón redondeado se puede crear usando la siguiente sintaxis:

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

Salida

A continuación se muestra la salida de ButtonPrimary:

Etiqueta

El componente de etiqueta se utiliza para mostrar texto estático. Cambie la página de inicio de la siguiente manera:

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

Aquí, textWrap envuelve el contenido de la etiqueta, si la etiqueta se extiende más allá del ancho de la pantalla.

Salida

A continuación se muestra la salida de Etiqueta:

Campo de texto

El componente TextField se utiliza para obtener información del usuario. Cambiemos nuestra página de inicio como se especifica a continuación:

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

Aquí,

  • el color representa el color del texto

  • backgroundColor representa el fondo del cuadro de texto

  • altura representa la altura del cuadro de texto

Salida

A continuación se muestra la salida del campo de texto:

Vista de texto

TextView Component se utiliza para obtener contenido de texto de varias líneas del usuario. Cambiemos nuestra página de inicio como se especifica a continuación:

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

Aquí, maxLength representa la longitud máxima aceptada por TextView .

Salida

A continuación se muestra la salida de TextView:

Barra de búsqueda

Este componente se utiliza para buscar consultas o enviar cualquier solicitud. Se define a continuación:

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

Podemos aplicar estilos -

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

A continuación se muestra la salida de SearchBarStyle:

Cambiar

El interruptor se basa en alternar para elegir entre las opciones. El estado predeterminado es falso. Se define a continuación:

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

La salida para el programa anterior se muestra a continuación:

Deslizador

Slider es un componente deslizante para elegir un rango numérico. Se define a continuación:

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

La salida para el programa anterior se da a continuación:

Progreso

El widget de progreso indica el progreso de una operación. El progreso actual se representa como una barra. Se define a continuación:

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

A continuación se muestra la salida del widget de progreso:

Indicador de actividad

ActivityIndicator muestra una tarea en progreso. Se define a continuación:

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

A continuación se muestra el resultado de ActivityIndicator:

Imagen

El widget de imagen se utiliza para mostrar una imagen. Se puede cargar usando la URL 'ImageSource'. Se define a continuación:

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

La salida para Image Widget es la que se muestra a continuación:

WebView

WebView muestra páginas web. Las páginas web se pueden cargar mediante URL. Se define a continuación:

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

La salida para el código anterior es como se muestra a continuación:

Selector de fechas

El componente DatePicker se utiliza para elegir la fecha. Se define a continuación:

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

La salida del componente DatePicker es la que se muestra a continuación:

TimePicker

El componente TimePicker se utiliza para elegir la hora. Se define a continuación:

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

A continuación se muestra la salida del componente TimePicker:

NativeScript proporciona una colección de componentes de contenedor con el único propósito de diseñar el componente de widget de IU. Los contenedores de diseño actúan como el componente principal y pueden tener uno o más componentes secundarios. Todos los componentes secundarios de un contenedor de diseño se pueden organizar según la técnica proporcionada por su contenedor de diseño principal.

NativeScript admite seis contenedores de diseños y son los siguientes:

  • Contenedor de diseño absoluto

  • Contenedor de diseño de muelle

  • Contenedor de diseño de cuadrícula

  • Contenedor de diseño de pila

  • Envase contenedor de diseño

  • Contenedor de diseño FlexBox

Aprendamos todos los conceptos de contenedor de diseño en detalle en este capítulo.

Diseño absoluto

AbsoluteLayoutcontainer es el contenedor de diseño más simple en NativeScript. AbsoluteLayout no impone ninguna restricción a sus hijos y colocará a sus hijos dentro de él utilizando un sistema de coordenadas bidimensional con la esquina superior izquierda como origen.

AbsoluteLayout usa cuatro propiedades de sus hijos para posicionarlos y son las siguientes:

top - Define la ubicación del niño desde el origen moviéndose hacia abajo en la dirección y.

left - Define la ubicación del niño desde el origen moviéndose hacia los lados en la dirección x.

width - Define el ancho del niño.

height - Define la altura del niño.

Agreguemos el contenedor AbsoluteLayout en la página de inicio de nuestra aplicación como se muestra a continuación:

<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>

Salida

La salida de AbsoluteLayout es la siguiente:

DockLayout

DocklayoutEl componente contenedor permite a sus hijos acoplarse dentro de él. Cada lado del contenedor (superior, inferior, izquierdo, derecho) puede acoplar un componente secundario. El contenedor DockLayout usa la propiedad dock de sus hijos para acoplarlos correctamente.

Los posibles valores de la propiedad dock son los siguientes:

top - El contenedor de diseño acopla el componente secundario en la esquina superior.

bottom - El contenedor de diseño acopla el componente secundario en la esquina inferior.

left - El contenedor de diseño acopla el componente secundario en la esquina izquierda.

right - El contenedor de diseño acopla el componente secundario en la esquina derecha.

Por defecto, DockLayoutcontenedor acopla su último componente hijo. Puede anular estableciendo su propiedad stretchLastChild en cero.

Agreguemos DockLayout contenedor en la página de inicio de nuestra aplicación como se muestra a continuación:

<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>

Salida

A continuación se muestra el resultado de DockLayout:

Diseño de cuadrícula

El componente contenedor GridLayout es uno de los contenedores de diseño complejo y organiza los elementos secundarios en formato tabular con filas y columnas. Por defecto, tiene una fila y una columna. Tiene las siguientes propiedades:

columns- Se utiliza para representar el ancho predeterminado de cada columna separada por,. Los valores posibles son número, * y palabra clave auto.

Dónde,

  • número indica un ancho de columna absoluto.

  • indica el ancho de una columna en relación con otras columnas. Puede ir precedido de un número para indicar cuántas veces el ancho de la columna debe ser relativo a otra columna. Por ejemplo, 2 * indica el ancho de la columna debe ser 2 veces el ancho de la columna más pequeña.

  • auto indica el ancho de la columna tan ancho como su hijo más ancho.

Por ejemplo, *, 2 * significa dos columnas y la segunda tendrá el doble del tamaño de la primera columna.

rows - Se utiliza para representar la altura predeterminada de cada fila separada por,. La representación de valores es similar a las columnas.

GridLayout usa las propiedades especificadas a continuación de sus hijos para diseñarlos:

row - Número de fila

col - Número de columna

rowSpan - número total de filas que abarca el contenido secundario dentro de un diseño.

colSpan - número total de columnas que abarca el contenido secundario dentro de un diseño.

Agreguemos el contenedor GridLayout en la página de inicio de nuestra aplicación como se muestra a continuación:

<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>

Salida

A continuación se muestra el resultado de GridLayout:

StackLayout

StackLayout organiza sus elementos secundarios en una línea unidimensional, ya sea horizontal o verticalmente. Se puede dimensionar en función del espacio en el diseño utilizando las opciones de diseño. Tiene una propiedad de orientación que se puede utilizar para especificar la dirección, horizontal o vertical.

Agreguemos el contenedor StackLayout en la página de inicio de nuestra aplicación como se muestra a continuación:

<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>

Salida

La salida de StackLayout es la que se muestra a continuación:

WrapLayout

WrapLayout se usa para envolver contenido en nuevas filas o columnas.

Tiene las siguientes tres propiedades:

orientation - mostrar ya sea horizontal o verticalmente.

itemWidth - ancho de diseño para cada niño.

itemHeight - altura de diseño para cada niño.

Agreguemos el contenedor WrapLayout en la página de inicio de nuestra aplicación como se muestra a continuación:

<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>

Salida

Diseño de caja flexible

El componente contenedor FlexboxLayout es uno de los contenedores de diseño avanzado. Proporciona la opción de renderizar un diseño simple a diseños muy complejos y sofisticados. Está basado en CSS Flexbox.

El componente FlexboxLayout tiene muchas propiedades y son las siguientes:

flexDirection

Representa la dirección en la que se organizan los componentes secundarios. Los posibles valores de flexDirection son los siguientes:

row - Los componentes del niño están dispuestos uno al lado del otro.

row-reverse - Los componentes secundarios están dispuestos uno al lado del otro, pero en sentido inverso.

column - Los componentes secundarios están dispuestos uno debajo del otro.

column-reverse - Los componentes secundarios están dispuestos uno debajo del otro pero en sentido inverso.

Agreguemos el contenedor FlexLayout en la página de inicio de nuestra aplicación como se muestra a continuación:

<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>

Salida

A continuación se muestra la salida de FlexLayout - Row -

Ahora, cambiemos el valor de flexDirection de row a row-reverse y verifiquemos cómo afecta el diseño.

<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>

Salida

A continuación se muestra la salida de Flex Layout - Row Reverse -

Cambiemos el valor de flexDirection de row-reverse a column y verifiquemos cómo afecta el diseño.

<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>

Salida

La salida para FlexLayout - Column se da a continuación:

Cambiemos el valor de flexDirection de column a column-reverse y verifiquemos cómo afecta el diseño.

<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>

Salida

A continuación se muestra la salida de FlexLayout - Column Reverse -

flexWrap

Representa si los componentes secundarios se procesarán en una sola fila / columna o fluirán en varias filas al ajustar en la dirección establecida por flexDirection.

Los valores posibles son los siguientes:

wrap - Envuelve los componentes secundarios, si no hay espacio disponible en la dirección dada (flexDirection).

wrap-reverse - Igual que la envoltura excepto que el componente fluye en dirección opuesta.

Agreguemos la propiedad flexWrap y luego establezcamos su valor como wrap. También agregue tres niños más como se especifica a continuación:

<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>

Salida

A continuación se muestra el resultado de flexWrap:

JustifyContent

Representa cómo se organizan los componentes secundarios entre sí y con la estructura general. Tiene tres propiedades como se especifica a continuación:

flex-end - Empaqueta el componente secundario hacia la línea final.

space-between - Empaqueta el componente secundario distribuyéndolo uniformemente en línea.

space-around - Similar a space-between, excepto que empaqueta el componente secundario distribuyéndolo uniformemente en línea, así como el mismo espacio alrededor de ellos.

Agreguemos también justifyContent y verifiquemos cómo se comporta:

<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>

Salida

A continuación se muestra el resultado de Flex Layout - JustifyContent -

El contenedor FlexLayout proporciona dos propiedades más para que sus hijos especifiquen el orden y la capacidad de encoger. Son los siguientes:

order - Determina el orden en el que se procesarán los elementos secundarios del contenedor FlexLayout.

flexShrink - Determina la capacidad de los niños de encogerse al nivel 0.

La navegación permite a los usuarios deslizarse rápidamente hacia la pantalla deseada o navegar a través de una aplicación o realizar una acción en particular. El componente de navegación le ayuda a implementar la navegación mediante simples clics de botones a patrones más complejos.

La navegación difiere sustancialmente entre la versión central y angular de NativeScript. Si bien la navegación del marco central es la base para el proceso de navegación, el modelo Angular de NativeScript adopta el concepto de navegación central y lo extiende para hacerlo compatible con el marco Angular.

Veamos tanto el concepto central de navegación como la adopción angular de la navegación en este capítulo.

Conceptos básicos

Entendamos cómo funciona la navegación en el núcleo de NativeScript en este capítulo.

En NativeScript, la navegación se divide en cuatro categorías diferentes según la dirección en la que se aplica, como se especifica a continuación:

  • Navegación hacia adelante

  • Navegación hacia atrás

  • Navegación lateral

  • Navegación inferior

Navegación hacia adelante

La navegación hacia adelante se refiere a la navegación de los usuarios a la pantalla en el siguiente nivel de jerarquía. Se basa en dos componentes de NativeScript,Frame y Page.

Frame

Frame es el componente de nivel raíz para la navegación. No es un contenedor visible pero actúa como contenedor de transiciones entre páginas.

Un ejemplo simple es el siguiente:

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

Aquí,

Frame navega hasta (o carga) el componente de la página destacada y lo representa.

Page

La página está junto al componente Frame y actúa como un contenedor para el componente UI. A continuación se define un ejemplo simple:

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

Aquí,

  • Inicialmente, Page carga todo el componente de IU de la pantalla y lo renderiza.

  • Cuando el usuario hace clic en el botón, lo llevará a another-page página.

Navegación hacia atrás

El método de navegación hacia atrás permite el movimiento hacia atrás a través de pantallas dentro de una aplicación o entre diferentes aplicaciones. Es la dirección opuesta a la navegación hacia adelante. El método simple goBack () se utiliza para volver a la página anterior.

Se define a continuación:

<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>

Aquí,

goBack() El método se activará cuando el usuario toque el botón. goBack() lleva a los usuarios a la página anterior, si hay alguna disponible.

Navegación lateral

La navegación lateral se refiere a la navegación entre pantallas en los mismos niveles de jerarquía. Se basa en un patrón de cubo. Se habilita a través de componentes de navegación específicos como BottomNavigation, Tabs, TabView, SideDrawer y Modal View.

Un ejemplo simple se define a continuación:

<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>

Aquí,

  • navigateToFeatured La función utiliza el método navigate () para navegar al usuario a la página destacada.

  • Similar, navigateToSearch La función llevará al usuario a la página de búsqueda.

También se puede acceder a la página del concentrador usando el método de navegación disponible en la pantalla de la página y uno puede salir de la página del concentrador usando el método goBack ().

Un ejemplo simple es el siguiente:

<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>

Navegación por la parte inferior y por pestañas

El estilo de navegación más común en las aplicaciones móviles es la navegación basada en pestañas. La navegación por pestañas se organiza en la parte inferior de la pantalla o en la parte superior debajo del encabezado. Se logra mediante el uso de TabView y el componente BottomNavigation .

Navegación basada en ángulo

NativeScript amplía su concepto de navegación para adaptarse al concepto de enrutamiento angular. NativeScript proporciona un nuevo módulo, NativeScriptRouterModule al extender Angular RouterModule.

El concepto de navegación angular de NativeScript se puede clasificar en la siguiente sección:

  • etiqueta de salida de enrutador de página

  • nsRouterLink atractivo

  • Clase RouterExtension

  • Enrutador personalizadoReuseStrategy

Aprendamos toda la navegación angular anterior en esta sección.

Salida del enrutador de página

Como se aprendió anteriormente, page-router-outlet es el reemplazo del router-outlet de Angular. page-router-outlet envuelve la estrategia Frame and Page del marco de navegación central de Nativescript. Cada página-enrutador-salida crea un nuevo componente de marco y cada componente configurado en la salida se empaquetará con el componente de página. Luego, el método de navegación nativo se usa para navegar a otra página / ruta.

Enlace de enrutador (nsRouterLink)

nsRouterLink es el reemplazo del RouterLink de Angular. Permite que el componente de la interfaz de usuario se vincule a otra página mediante la ruta. nsRouterLink también proporciona a continuación dos opciones:

pageTransition- Se utiliza para configurar la animación de transición de página. true habilita la transición predeterminada. false desactiva la transición. Valores específicos como slide, fadein, etc., establecen la transición particular.

clearHistory - true borra el historial de navegación de nsRouterLink.

Un código de ejemplo simple es el siguiente:

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

Extensión del enrutador

NativeScript proporciona la clase RouterExtensions y expone la función de navegación del núcleo NativeScript.

Los métodos expuestos por RouterExtensions son los siguientes:

  • navigate

  • navigateByUrl

  • back

  • canGoBack

  • backToPreviousPage

  • canGoBackToPreviousPage

Un código de ejemplo simple que usa RouterExtensions es el siguiente:

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

Estrategia de reutilización de rutas personalizadas

NativeScript utiliza una estrategia de reutilización de rutas personalizada (RouterReuseStrategy) para adaptarse a la arquitectura de una aplicación móvil. Una aplicación móvil se diferencia en ciertos aspectos de una aplicación web.

Por ejemplo, la página se puede destruir en una aplicación web cuando el usuario navega fuera de la página y la vuelve a crear cuando el usuario navega a la página. Pero, en la aplicación móvil, la página se conservará y reutilizará. Estos conceptos se tienen en cuenta al diseñar el concepto de enrutamiento.

Rutas

Un módulo de enrutamiento simple en la aplicación NativeScript Angular será el siguiente:

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 { }

Aquí,

El módulo de enrutamiento es muy similar a la versión angular, excepto muy pocas excepciones. En realidad, NativeScript usa su estrategia de navegación central exponiéndola de una manera similar al marco Angular.

En cada aplicación de GUI, los eventos juegan un papel muy importante para permitir la interacción del usuario. Siempre que el usuario interactúe con la aplicación, se activará un evento y se ejecutará la acción correspondiente.

Por ejemplo, cuando el usuario hace clic en el botón Iniciar sesión en la página de inicio de sesión de una aplicación, se activa el proceso de inicio de sesión.

Los eventos involucran a dos actores:

  • Event sender - objeto, que plantea el evento real.

  • Event listener - función, que escucha un evento en particular y luego se ejecuta cuando se dispara un evento.

Clase observable

Es una clase predefinida para manejar eventos. Se define a continuación:

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

En NativeScript, casi todos los objetos se derivan de la clase Observable y, por lo tanto, todos los objetos admiten eventos.

Oyente de eventos

Entendamos cómo crear un objeto y agregar un detector de eventos al objeto en este capítulo.

Paso 1

Cree un botón que se utilice para generar un evento como se especifica a continuación:

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

Paso 2

A continuación, agregue texto al botón como se especifica a continuación:

testButton.text = "Click";

Paso 3

Cree una función, onTap como se especifica a continuación:

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

Etapa 4

Ahora adjunte el evento tap a la función onTap como se especifica a continuación:

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

Una forma alternativa de agregar un detector de eventos es la siguiente:

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

Paso 5

Una forma alternativa de adjuntar eventos es a través de la interfaz de usuario como se especifica a continuación:

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

Aquí,

$ evento es de tipo EventData. EventData contiene dos propiedades y son las siguientes:

Object- Instancia observable que se usa para generar un evento. En este escenario, es un objeto Botón.

EventName- Es el nombre del evento. En este escenario, es un evento de tap.

Paso 6

Finalmente, un detector de eventos se puede desconectar / eliminar en cualquier momento como se especifica a continuación:

testButton.off(Button.onTap);

También puede utilizar otro formato como se muestra a continuación:

testButton.removeEventListener(Button.onTap);

Modificación de BlankNgApp

Modifiquemos la aplicación BlankNgApp para comprender mejor los eventos en NativeScript.

Paso 1

Abra la interfaz de usuario del componente de inicio, src/app/home/home.component.html y agregue el código siguiente -

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

Aquí,

  • tap es el evento y Button es el evento de recaudación.

  • onButtonTap es el detector de eventos.

Paso 2

Abra el código del componente de inicio, ‘src/app/home/home.component.ts’ y actualice el siguiente código -

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

Aquí,

  • Se agregó un nuevo detector de eventos, onButtonTap.

  • Imprima el nombre del evento, toque y presione el texto del botón, active un evento en la consola.

Paso 3

Ejecute la aplicación y toque el botón. Imprime la siguiente línea en la consola.

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

El enlace de datos es uno de los conceptos avanzados admitidos por NativeScript. NativeScript sigue el concepto de enlace de datos angular lo más cerca posible. El enlace de datos permite que el componente de la interfaz de usuario muestre / actualice el valor actual del modelo de datos de la aplicación sin ningún esfuerzo de programación.

NativeScript admite dos tipos de enlace de datos. Son los siguientes:

One-Way data binding - Actualiza la interfaz de usuario cada vez que se cambia el modelo.

Two-Way data binding- Sincroniza la interfaz de usuario y el modelo. Siempre que se actualiza el modelo, la interfaz de usuario se actualiza automáticamente y también cada vez que la interfaz de usuario obtiene datos del usuario (la interfaz de usuario se actualiza), el modelo se actualizará.

Aprendamos ambos conceptos en esta sección.

Enlace de datos unidireccional

NativeScript proporciona una opción simple para habilitar el enlace de datos unidireccional en un componente de la interfaz de usuario. Para habilitar el enlace de datos unidireccional, simplemente agregue corchetes en la propiedad de la IU de destino y luego asígnele la propiedad del modelo necesaria.

Por ejemplo, para actualizar el contenido de texto de un componente de etiqueta, simplemente cambie el código de la interfaz de usuario como se muestra a continuación:

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

Aquí,

this.model.prop se refiere a la propiedad del modelo, this.model.

Cambiemos nuestra BlankNgApp para comprender el enlace de datos unidireccional.

Paso 1

Agregue un nuevo modelo, Usuario (src / model / user.ts) de la siguiente manera:

export class User { 
   name: string 
}

Paso 2

Interfaz de usuario abierta de nuestro componente, src/app/home/home.component.html y actualice el código de la siguiente manera:

<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>

Aquí,

  • El texto de la etiqueta se establece en el nombre de propiedad del modelo de usuario.

  • El evento de toque de botón se adjunta al método onButtonTap.

Paso 3

Código abierto del componente de inicio, src/app/home/home.component.ts y actualice el código de la siguiente manera:

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

Aquí,

  • se importa el modelo de usuario

  • El objeto de usuario se crea en el constructor del componente

  • Se implementa el evento onButtonTap. La implementación de onButtonTap actualiza el objeto Usuario y establece el nombre de la propiedad como Usuario2

Etapa 4

Compile y ejecute la aplicación y haga clic en el botón para cambiar el modelo y cambiará automáticamente el Label texto.

El estado inicial y final de la aplicación es el siguiente:

Estado inicial

El estado inicial de enlace de datos unidireccional se muestra a continuación:

Estado final

El estado final de enlace de datos unidireccional se muestra a continuación:

Enlace de datos bidireccional

NativeScript también proporciona enlace de datos bidireccional para una funcionalidad avanzada. Vincula los datos del modelo a la interfaz de usuario y también vincula los datos actualizados en la interfaz de usuario al modelo.

Para hacer un enlace de datos bidireccional, use la propiedad ngModel y luego rodee con [] y () como se muestra a continuación:

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

Cambiemos la aplicación BlankNgApp para comprender mejor el enlace de datos bidireccional.

Paso 1

Importar NativeScriptFormsModule al HomeModule (src/app/home/home.module.ts) como se especifica a continuación -

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 { }

Aquí,

NativeScriptFormsModule habilita el enlace de datos bidireccional. De lo contrario, el enlace de datos bidireccional no funcionará como se esperaba.

Paso 2

Cambie la interfaz de usuario del componente de inicio como se indica a continuación:

<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>

Aquí,

La propiedad de texto del componente de etiqueta se establece con enlace de datos unidireccional. Si el usuario del modelo se actualiza, su propiedad de texto se actualizará automáticamente.

El componente TextField establece el ngModel como this.user.name. Si el usuario del modelo se actualiza, su propiedad de texto se actualizará automáticamente. Al mismo tiempo, si el usuario cambia el valor de TextField, el modelo también se actualiza. Si el modelo se actualiza, también activará los cambios de propiedad de texto de Label. Por lo tanto, si el usuario cambia los datos, se mostrarán en la propiedad de texto de Label.

Paso 3

Ejecute la aplicación e intente cambiar el valor del cuadro de texto.

El estado inicial y final de la aplicación será similar al que se especifica a continuación:

Estado inicial

Enlace de datos bidireccional: el estado inicial se indica a continuación:

Estado final

Enlace de datos bidireccional - El estado final se muestra a continuación -

Un módulo NativeScript contiene un conjunto de funcionalidades relacionadas empaquetadas como una sola biblioteca. Aprendamos los módulos proporcionados por el marco NativeScript.

Contiene funcionalidades básicas del marco NativeScript. Entendamos los módulos centrales de este capítulo.

Solicitud

La aplicación contiene la implementación específica de la plataforma de la aplicación móvil. El módulo básico simple se define a continuación:

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

Consola

El módulo de consola se utiliza para registrar mensajes. Tiene los siguientes métodos:

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

Configuraciones de la aplicación

El módulo de configuración de la aplicación contiene un método para administrar la configuración de la aplicación. Para agregar este módulo, necesitamos agregar el siguiente código:

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

Algunos métodos disponibles en la configuración de la aplicación son los siguientes:

  • setBoolean (clave: cadena, valor: booleano) - establecer objeto booleano

  • setNumber (clave: cadena, valor: número) - objeto de número de conjunto

  • setString (clave: cadena, valor: cadena) - establece el objeto cadena

  • getAllKeys (): contiene todas las claves almacenadas

  • hasKey (clave: cadena): comprueba si hay una clave presente o no

  • clear - borra los valores almacenados

  • eliminar: elimina cualquier entrada basada en la clave.

Un ejemplo simple que usa la configuración de la aplicación es el siguiente:

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

Este módulo se utiliza para manipular httpsolicitud y respuesta. Para agregar este módulo en su aplicación, agregue el siguiente código:

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

Podemos enviar datos utilizando los siguientes métodos:

getString- Se utiliza para realizar solicitudes y descargar los datos de la URL como una cadena. Se define a continuación:

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

getJSON- Se utiliza para acceder a datos de JSON. Se define a continuación:

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

getImage: Descarga el contenido de la URL especificada y devuelve el objeto ImageSource. Se define a continuación:

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

getFile - Tiene dos argumentos URL y ruta de archivo.

  • URL - descarga los datos.

  • File path- guardar los datos de la URL en el archivo. Se define a continuación:

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

request- Tiene argumento de opciones. Se utiliza para solicitar opciones y devolver el objeto HttpResponse. Se define a continuación:

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

Fuente de imagen

El módulo de fuente de imagen se utiliza para guardar la imagen. Podemos agregar este módulo usando la siguiente declaración:

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

Si desea cargar imágenes desde el recurso, use el siguiente código:

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

Para agregar una imagen desde un archivo local, use el siguiente comando:

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

Para guardar la imagen en la ruta del archivo, use el siguiente comando:

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

Temporizador

Este módulo se utiliza para ejecutar código en intervalos de tiempo específicos. Para agregar esto, necesitamos usarrequire -

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

Se basa en dos métodos:

setTimeout- Se utiliza para retrasar la ejecución. Se representa en milisegundos.

setInterval - Se utiliza para aplicar de forma recurrente a intervalos específicos.

Rastro

Este módulo es útil para depurar. Da la información de registro. Este módulo se puede representar como:

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

Si desea habilitar en su aplicación, use el siguiente comando:

traceModule.enable();

ui / image-cache

El módulo de caché de imágenes se usa para manejar solicitudes de descarga de imágenes y almacena en caché las imágenes descargadas. Este módulo se puede representar como se muestra a continuación:

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

conectividad

Este módulo se utiliza para recibir la información de conexión de la red conectada. Puede representarse como:

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

Módulos de funcionalidad

Los módulos de funcionalidad incluyen muchos módulos específicos del sistema / plataforma. Algunos de los módulos importantes son los siguientes:

platform- Se utiliza para mostrar la información sobre su dispositivo. Se puede definir como se indica a continuación:

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

fps-meter- Se utiliza para capturar fotogramas por segundo. Se puede definir como se indica a continuación:

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

file-system- Se utiliza para trabajar con el sistema de archivos de su dispositivo. Se define a continuación:

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

ui/gestures - Se usa para trabajar con gestos de UI.

Módulo de interfaz de usuario

El módulo UI incluye el componente UI y su funcionalidad relacionada. Algunos de los módulos importantes de la interfaz de usuario son los siguientes:

  • frame

  • page

  • color

  • text/formatted-string

  • xml

  • styling

  • animation

El paquete npm se usa para agregar funcionalidad nativa. Con este paquete, podemos instalar, buscar o eliminar cualquier complemento. Esta sección explica los complementos en detalle.

Comandos

add - Se utiliza para instalar complementos.

update - Actualiza el complemento especificado y modifica sus dependencias.

remove - Elimina el complemento.

build - Se utiliza para crear complementos para proyectos de iOS o Android.

create - Crea un complemento para su proyecto.

Agregar complemento

La siguiente sintaxis se usa para agregar un nuevo complemento:

tns plugin add <plugin-name>

Por ejemplo, si desea agregar nativescript-barcodescanner, puede usar el siguiente código:

tns plugin add nativescript-barcodescanner

Podrías ver la siguiente respuesta:

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

También puede usar el módulo npm para agregar el complemento anterior:

npm install nativescript-barcodescanner

Ahora, NativeScript CLI descarga el complemento de npm y lo agrega dentro de su carpeta node_modules.

Si desea agregar el complemento directamente a su package.json y resolver todos los problemas de dependencia, puede usar el siguiente comando en lugar del anterior:

npm i nativescript-barcodescanner

Si desea instalar las dependencias de un desarrollador durante el desarrollo, use el siguiente código:

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

Aquí,

tns-platform-declarations es una dependencia de desarrollador requerida solo para intelliSense durante el proceso de desarrollo.

Importación de complementos

Ahora, hemos instalado nativescript-barcodescanner plugin. Permítanos agregar dentro de su proyecto usando el siguiente comando:

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

Actualización de complementos

Este método se utiliza para actualizar un complemento específico para que desinstale el anterior e instale una nueva versión y modifique sus dependencias. Se define a continuación:

tns plugin update <Plugin name version>

Eliminar complemento

Si desea eliminar el complemento, si no es necesario, puede usar la siguiente sintaxis:

tns plugin remove <plugin-name>

Por ejemplo, si desea eliminar el nativescript-google-maps-sdk instalado anteriormente, use el siguiente comando:

tns plugin remove nativescript-barcodescanner

Podrías ver la siguiente respuesta:

Successfully removed plugin nativescript-barcodescanner

Complementos de construcción

Se utiliza para crear los archivos de proyecto específicos de Android del complemento ubicados en plataformas / android. Construyamos el pugin nativescript-barcodescanner usando el siguiente comando:

tns plugin build nativescript-barcodescanner

Crear complementos

Los complementos de NativeScript son simples módulos de JavaScript. Está definido dentro del archivo src \ package.json de su aplicación. Este módulo se utiliza para crear un nuevo proyecto para el desarrollo de complementos de NativeScript. Se define a continuación:

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

Esta sección explica la descripción general del acceso a las API nativas mediante JavaScript.

Marshalling

NativeScript Runtime proporciona una conversión de tipo implícita para las plataformas Android e iOS. Este concepto se conoce como clasificación. Por ejemplo, la plataforma NativeScript-iOS puede convertir implícitamente los tipos de datos de JavaScript y Objective-C de manera similar, Java / Kotlin se puede asignar fácilmente a los tipos y valores de proyectos de JavaScript. Entendamos brevemente cómo realizar la clasificación en cada tipo uno por uno.

Valores numéricos

Podemos convertir fácilmente los tipos de datos numéricos de iOS y Android en números de JavaScript. La conversión numérica simple para iOS a JavaScript se define a continuación:

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

Aquí,

La función nativa max () se convierte en un número de JavaScript.

Entorno Android

Java admite diferentes tipos numéricos como byte, short, int, float, double y long. JavaScript solo tiene tipo de número.

Considere una clase de Java simple que se muestra a continuación:

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

Aquí,

El código anterior contiene dos argumentos enteros. Podemos llamar al objeto de código anterior usando JavaScript como se muestra a continuación:

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

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

Instrumentos de cuerda

Las cadenas de Android se definen en java.lang.string y las cadenas de iOS se definen en NSSring. Veamos cómo realizar la clasificación en ambas plataformas.

Androide

Las cadenas son inmutables, pero los búferes de cadenas admiten cadenas mutables.

El siguiente código es un ejemplo de mapeo 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 clase booleana se define en java.lang.Boolean. Esta clase envuelve un valor booleano en un objeto. Podemos convertir fácilmente booleano a String y viceversa. El ejemplo simple se define como se indica a continuación:

//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

Entorno iOS

La clase NSString es inmutable pero su subclase NSMutableString es inmutable. Esta clase contiene una colección de métodos para trabajar con cadenas. Se declara de la siguiente manera:

class NSString : NSObject

Considere una declaración de objetivo-c simple como se muestra a continuación:

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

NSStrings se puede asignar fácilmente a cadenas de JavaScript.

Formación

Esta sección explica cómo realizar el cálculo de referencias en matrices. Tomemos primero un ejemplo del entorno iOS.

Declaración de matriz

class NSArray : NSObject

Aquí,

NSArray se utiliza para gestionar la colección ordenada de objetos denominados matrices. Se utiliza para crear una matriz estática. Su subclaseNSMutableArray se utiliza para crear matrices dinámicas.

Considere que los objetos NSArray se pueden crear utilizando literales de matriz como se muestra a continuación:

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

Ahora, podemos mapear esta matriz en JavaScript como se muestra a continuación:

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

Esto devolverá la salida como falsa.

Declaración de matriz de Android

Las matrices de Java se definen en java.util.Arrays. Esta clase contiene varios métodos para manipular matrices. A continuación se muestra un ejemplo:

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

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

Clases y objetos

Las clases y los objetos son conceptos básicos de la programación orientada a objetos. La clase es un prototipo definido por el usuario. El objeto es una instancia de clase. La clase representa el conjunto de propiedades o métodos que son comunes a todos los objetos de un tipo. Entendamos las clases y los objetos nativos para ambos entornos de desarrollo móvil.

Entorno Android

Las clases Java y Kotlin tienen identificadores únicos indicados por el nombre completo del paquete.

Por ejemplo,

android.view.View- Es una clase de interfaz de usuario básica para el diseño de la pantalla y la interacción con el usuario. Podemos acceder a esta clase en JavaScript como se muestra a continuación:

const View = android.view.View;

Primero, importamos la clase usando la siguiente declaración:

import android.view.View;

A continuación, cree una clase como se indica a continuación:

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

En la misma clase anterior, podemos acceder a la función de JavaScript usando el siguiente código:

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

De manera similar, podemos acceder a interfaces, constantes y enumeraciones dentro de los paquetes java.lang.

Entorno iOS

Las clases de Objective-C se definen en dos secciones @interface y @implementation. La definición de clase comienza con la palabra clave@interface Seguido por el interface(class)nombre. En Objective-C, todas las clases se derivan de la clase base llamada NSObject.

Es la superclase de todas las clases de Objective-C. La clase Círculo simple se define como se muestra a continuación:

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

Considere una clase con un método como se muestra a continuación:

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

Esta clase se puede convertir a javascript usando el siguiente código:

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

JavaScript instanceofEl operador se utiliza para verificar si un objeto hereda de una clase determinada. Esto se puede definir como:

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

Aquí,

Las instancias de Objective-C se crean utilizando métodos alloc, init o nuevos. En el ejemplo anterior, podemos crear fácilmente la inicialización de objetos utilizando un nuevo método como se muestra a continuación:

var obj = MyClass.new();

Del mismo modo, puede acceder a propiedades y métodos estáticos.

Crear y publicar su aplicación hace que su aplicación de Android esté disponible para todos los usuarios. Google Play es una plataforma de publicación sólida. Le ayuda a publicar y distribuir sus aplicaciones de Android a todos los usuarios de todo el mundo. Este capítulo explica cómo publicar su aplicación nativa en Google Play.

Compañero de NativeScript

SideKick es un cliente GUI y es compatible con todo tipo de sistema operativo. Simplifica el proceso CLI de NativeScript y ayuda a crear aplicaciones móviles.

Publique su aplicación de Sidekick en Google Play Console

La descarga e instalación de sidekick depende de su sistema operativo. Siga los pasos a continuación para ejecutar su aplicación en Sidekick.

Step 1: Launch Sidekick

Iniciemos Sidekick. Se parece a la imagen de abajo:

Step 2: Build your device

Ahora, abra su aplicación desde su dispositivo y seleccione la opción de compilación de la barra de herramientas y seleccione Android. Obtendrá una respuesta similar a la siguiente imagen:

Step 3: Properties

Haga clic en la pestaña de propiedades y agregue su configuración de Android. La pantalla se ve similar a la de abajo:

Step 4: Plugins

Sidekick ayuda a encontrar los complementos de los que depende para su aplicación. Haga clic en la pestaña de complementos y aparecerá una lista de lo siguiente:

Step 5: Android Certificates

Haga clic en el icono de la rueda dentada de Android y elija la opción de exploración, luego seleccione un certificado almacenado en su sistema de archivos. Se muestra a continuación:

Después de seleccionar eso, cierre el cuadro de diálogo.

Step 6: Build your application

Finalmente, haga clic en la opción de compilación local del tipo de compilación y seleccione la opción de liberación de la configuración. Después de eso, cree su aplicación.

Step 7: Application package

Una vez que se completa la compilación, generará una ruta y apkarchivo. Guarde la ubicación del paquete de la aplicación. Este archivo apk se utiliza para cargarlo en la tienda Google Play.

Step 8: Publish in Google Play

Seleccione la opción de publicación de la barra de herramientas y seleccione Google Play. Luego, agregue el cuadro de diálogo Administrar certificados de Android para Google Play Store. Se muestra a continuación:

Después de eso, seleccione el tipo de compilación y proporcione la clave JSON de la cuenta de servicio, luego seleccione las pistas Alfa, Beta o Producción y finalmente haga clic en cargar.

Publica tu aplicación en Google Play

Para publicar su aplicación en la consola de Google Play, debe cumplir con los siguientes requisitos previos.

Prerrequisitos

  • Debes estar registrado en Google Play

  • Tienes una identidad de firma de código autofirmado de Google Play válida

Procedimiento para publicar su aplicación

Los pasos siguientes son útiles para comprender cómo lanzar su aplicación en la tienda Google Play.

Step 1: Login Google Play console

Abra la consola de Google Play e inicie sesión con su cuenta.

Step 2: Create an app

Vaya a la pestaña Todas las aplicaciones, haga clic en Crear aplicación y cree una nueva aplicación. Ahora, agregue el idioma predeterminado, el título de la aplicación finalmente haga clic en continuar para ir más allá.

Step 3: Fill required fields

Vaya a la pestaña de la ficha de Play Store y complete los campos obligatorios, luego complete los elementos necesarios y guarde todos los cambios.

Step 4: Price and distribution

Vaya a la pestaña Precios y distribución, complete todas las configuraciones y guarde todos los cambios.

Step 5: Release your app

Elija la pestaña Lanzamientos de aplicaciones y seleccione Alfa, Beta. Se utiliza para probar su aplicación. Y seleccione pistas de producción. Se utiliza para publicar su aplicación en Google Play. Finalmente agregue el paquete de la aplicación (apk).

Step 6: Review your app

Este es tu paso final. En la Revisión, verifique si hay algún problema. Si no hay problemas, confirme el lanzamiento para publicar su aplicación.

Este capítulo explica cómo publicar su aplicación nativa en App Store. Siga los pasos a continuación para publicar su aplicación.

Prerrequisitos

Para realizar esto, debe necesitar los siguientes requisitos previos:

  • Certificado de distribución

  • Perfil de aprovisionamiento de distribución

  • ID de paquete registrado en el centro de desarrollo de iOS

  • Registro de la aplicación en iTunes Connect

Pasos para publicar su aplicación

A continuación se muestran los pasos para publicar su aplicación:

Paso 1: Abra NativeScript Sidekick

Inicie NativeScript Sidekick y abra su aplicación en Sidekick.

Paso 2: seleccione publicar

Vaya a la barra de herramientas y seleccione la opción de publicación de la barra de herramientas. Se muestra a continuación:

Ahora, seleccione la opción Apple App Store. Se parece a la imagen de abajo:

Paso 3: administrar la provisión y los certificados de iOS

Haga clic en el icono de la rueda dentada de la App Store de Apple, elija la opción de exploración y agregue los detalles.

Paso 4: crea tu aplicación

A continuación, haga clic en la opción de compilación y cree su aplicación y espere hasta que se complete el proceso.

Paso 5: proporcione credenciales

Este es tu paso final. Especifique el nombre de usuario y la contraseña de Apple en su cuenta, haga clic en cargar y verifique el mensaje de confirmación. Si desea enviar su aplicación para su revisión, vaya a iTunes Connect y envíelo.

La prueba es una fase muy importante en el ciclo de vida de desarrollo de una aplicación. Asegura una aplicación de calidad. Necesita una planificación y ejecución cuidadosas. También es la fase más lenta del desarrollo. El marco NativeScript proporciona un amplio soporte para las pruebas automatizadas de una aplicación.

Tipos de pruebas

Generalmente, hay tres tipos de procesos de prueba disponibles para probar una aplicación. Son los siguientes:

Examen de la unidad

La prueba unitaria es el método más sencillo para probar una aplicación. Se basa en asegurar la corrección de un fragmento de código (una función, en general) o un método de una clase. Pero, no refleja el entorno real y posteriormente. Es la menor opción para encontrar los errores.

Generalmente, NativeScript utiliza los marcos de prueba unitarios Jasmine, Mocha con Chai y QUnit.

Para realizar esto, primero debe configurar en su proyecto usando el siguiente comando:

tns test init

Ahora, obtienes la siguiente respuesta:

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

Ahora, seleccione jasmine framework y su pantalla se ve similar a esto -

? 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.

Ahora, el archivo de prueba se crea dentro de src \ tests \ example.ts.

Crea tus pruebas

Agreguemos una prueba simple dentro del archivo example.ts como se muestra a continuación:

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

Aquí,

Primero, verifique si el contador es igual a 10 y verifique si quedan 10 toques en el mensaje.

Ejecutemos la prueba en el siguiente paso.

Ejecute sus pruebas

Ahora, ejecute la prueba en un dispositivo conectado con Android o iOS usando el siguiente comando:

tns test android

Esto devolverá el siguiente estado:

? 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

Luego elija la siguiente opción:

? 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 
.....

Para ejecutar su conjunto de pruebas en el simulador de Android, ejecute el siguiente comando:

tns test android --emulator

Ahora, karma server prepara las compilaciones y despliega su proyecto.

Prueba de extremo a extremo (E2E)

Las pruebas unitarias son un proceso pequeño, simple y rápido, mientras que en la fase de prueba E2E participan múltiples componentes y trabajan juntos, lo que cubre los flujos de la aplicación. Esto no se pudo lograr mediante pruebas unitarias y de integración.

NativeScript AppiumEl complemento se utiliza para realizar pruebas de automatización E2E. Bueno, Appium es un marco de prueba de código abierto para aplicaciones móviles. Para agregar este marco en su proyecto, debe tener la última versión de XCode o Android SDK por encima de la 25.3.0.

Instalar Appium

Instalemos Appium globalmente usando el módulo npm -

npm install -g appium

Ahora, podría ver la siguiente respuesta:

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

Agregar complemento

Agreguemos nativescript-dev-appium plugin como devDependency para su proyecto usando el siguiente comando:

$ npm install -D nativescript-dev-appium

Después de ejecutar esto, elija mocha framework y obtendrá una respuesta similar a esta:

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

Ahora, los archivos se almacenan dentro de la carpeta de su proyecto.

Construye tu dispositivo

Construyamos un dispositivo Android usando el siguiente comando:

tns build android

El comando anterior ejecutará las pruebas debe especificar las capacidades de destino. Si tiene un dispositivo iOS, puede compilar usandoiOS dispositivo.

Ejecutar prueba

Ahora, hemos configurado el dispositivo. Ejecutemos nuestra prueba usando el siguiente comando:

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

Aquí,

El nombre de capacidad está definido dentro de su aplicación. e2e/config/appium.capabilities.json.

Salida

NativeScript - Conclusión

NativeScript es una gran aplicación móvil para que los desarrolladores web prueben su aplicación por completo de una manera muy fácil sin hacer esfuerzos adicionales. Los desarrolladores pueden desarrollar con confianza una aplicación excelente y exitosa sin ningún problema en un corto período de tiempo.