NativeScript-아키텍처

NativeScript는 모바일 애플리케이션을 만들기위한 고급 프레임 워크입니다. 모바일 애플리케이션 생성의 복잡성을 숨기고 고도로 최적화되고 고급 모바일 애플리케이션을 생성하기 위해 다소 간단한 API를 노출합니다. NativeScript를 사용하면 초급 개발자도 Android와 iOS에서 모바일 애플리케이션을 쉽게 만들 수 있습니다.

이 장에서 NativeScript 프레임 워크의 아키텍처를 이해하겠습니다.

소개

NativeScript 프레임 워크의 핵심 개념은 개발자가 하이브리드 스타일 모바일 애플리케이션을 만들 수 있도록하는 것입니다. 하이브리드 애플리케이션은 플랫폼 별 브라우저 API를 사용하여 일반 모바일 애플리케이션 내에서 웹 애플리케이션을 호스팅하고 JavaScript API를 통해 애플리케이션에 대한 시스템 액세스를 제공합니다.

NativeScript는 JavaScript language개발자에게 효율적인 프레임 워크를 제공합니다. 이후JavaScript클라이언트 측 프로그래밍 (웹 개발)을위한 사실상의 표준이며 모든 개발자는 JavaScript 언어를 잘 알고 있으므로 개발자가 NativeScript 프레임 워크에 쉽게 들어갈 수 있도록 도와줍니다. 낮은 수준에서 NativeScript는 다음과 같은 JavaScript 플러그인 모음을 통해 네이티브 API를 노출합니다.Native plugins.

NativeScript는 Native 플러그인을 기반으로 구축되며 높은 수준의 사용하기 쉬운 JavaScript 모듈 을 많이 제공합니다 . 각 모듈은 카메라 액세스, 화면 디자인 등과 같은 특정 기능을 수행합니다. 이러한 모든 모듈을 여러 방법으로 결합하여 복잡한 모바일 애플리케이션을 설계 할 수 있습니다.

아래 다이어그램은 NativeScript 프레임 워크의 높은 수준의 개요를 보여줍니다.

NativeScript Application − NativeScript 프레임 워크를 통해 개발자는 Angular 스타일 애플리케이션 또는 Vue 스타일 애플리케이션을 사용할 수 있습니다.

JavaScript Modules − NativeScript 프레임 워크는 UI 모듈, 애플리케이션 모듈, 코어 모듈 등으로 명확하게 분류 된 풍부한 JavaScript 모듈 세트를 제공합니다. 모든 모듈은 애플리케이션에서 언제든지 액세스하여 모든 수준의 복잡한 애플리케이션을 작성할 수 있습니다.

JavaScript plugins− NativeScript 프레임 워크는 플랫폼 관련 기능에 액세스하기위한 대규모 JavaScript 플러그인 모음을 제공합니다. 모듈은 JavaScript 플러그인을 사용하여 플랫폼 별 기능을 제공합니다.

Native plugins− 네이티브 플러그인은 자바 스크립트 플러그인에서 추가로 사용될 시스템 기능을 래퍼하기 위해 플랫폼 별 언어로 작성됩니다.

Platform API − 플랫폼 공급 업체에서 제공하는 API.

간단히 말해 NativeScript 응용 프로그램은 모듈을 사용하여 작성되고 구성됩니다. 모듈은 순수 JavaScript로 작성되고 모듈은 플러그인을 통해 플랫폼 관련 기능 (필요할 때마다)에 액세스하고 마지막으로 플러그인은 플랫폼 API와 JavaScript API를 연결합니다.

NativeScript 응용 프로그램의 작업 흐름

앞서 배운 것처럼 NativeScript 애플리케이션은 모듈로 구성되어 있습니다. 각각의 모든 모듈은 특정 기능을 활성화합니다. NativeScript 응용 프로그램을 부트 스트랩하는 두 가지 중요한 모듈 범주는 다음과 같습니다.

  • 루트 모듈

  • 페이지 모듈

루트 및 페이지 모듈은 애플리케이션 모듈로 분류 할 수 있습니다. 응용 프로그램 모듈은 NativeScript 응용 프로그램의 진입 점입니다. 페이지를 부트 스트랩하고 개발자가 페이지의 사용자 인터페이스를 만들 수 있으며 마지막으로 페이지의 비즈니스 논리를 실행할 수 있습니다. 애플리케이션 모듈은 다음 세 항목으로 구성됩니다.

  • XML로 코딩 된 사용자 인터페이스 디자인 (예 : page.xml / page.component.html)

  • CSS로 코딩 된 스타일 (예 : page.css / page.component.css)

  • JavaScript에서 모듈의 실제 비즈니스 로직 (예 : page.js / page.component.ts)

NativeScript는 응용 프로그램 페이지를 디자인하기 위해 많은 UI 구성 요소 (UI 모듈 아래)를 제공합니다. UI 구성 요소는 Angular 기반 응용 프로그램에서 XML 형식 또는 HTML 형식으로 표현할 수 있습니다. 애플리케이션 모듈은 UI 구성 요소를 사용하여 페이지를 디자인하고 별도의 XML 인 page.xml / page.component.html에 디자인을 저장합니다 . 디자인은 표준 CSS를 사용하여 스타일을 지정할 수 있습니다.

애플리케이션 모듈은 별도의 CSS 인 page.css / page.component.css에 디자인 스타일을 저장합니다 . 페이지의 기능은 JavaScript / TypeScript를 사용하여 수행 할 수 있으며, 플랫폼 기능은 물론 디자인에 대한 전체 액세스 권한이 있습니다. 애플리케이션 모듈은 별도의 파일 인 page.js / page.component.ts를 사용하여 페이지의 실제 기능을 코딩합니다.

루트 모듈

NativeScript는 UI 컨테이너를 통해 사용자 인터페이스와 사용자 상호 작용을 관리합니다. 모든 UI 컨테이너에는 루트 모듈 이 있어야하며 이를 통해 UI 컨테이너가 UI를 관리합니다. NativeScript 애플리케이션에는 두 가지 유형의 UI 컨테이너가 있습니다.

Application Container− 모든 NativeScript 응용 프로그램에는 하나의 응용 프로그램 컨테이너가 있어야하며 application.run () 메서드를 사용하여 설정됩니다. 응용 프로그램의 UI를 초기화합니다.

Model View Container− NativeScript는 모델보기 컨테이너를 사용하여 모달 대화 상자를 관리합니다. NativeScript 응용 프로그램에는 여러 모델보기 컨테이너가있을 수 있습니다.

모든 루트 모듈에는 콘텐츠로 하나의 UI 구성 요소 만 있어야합니다. UI 구성 요소는 다른 UI 구성 요소를 자식으로 가질 수 있습니다. NativeScript는 TabView, ScrollView 등과 같은 많은 UI 구성 요소를 자식 기능과 함께 제공합니다. 이를 루트 UI 구성 요소로 사용할 수 있습니다. 한 가지 예외는 Frame으로 , 자식 옵션은 없지만 루트 구성 요소로 사용할 수 있습니다. 프레임은 페이지 모듈을로드하는 옵션과 다른 페이지 모듈 로 이동하는 옵션 도 제공합니다.

페이지 모듈

NativeScript에서 각 페이지는 기본적으로 Page Module 입니다. 페이지 모듈은 NativeScript에서 제공하는 풍부한 UI 구성 요소 세트를 사용하여 설계되었습니다. 페이지 모듈은 프레임 구성 요소 (defaultPage 속성 사용 또는 navigate () 메서드 사용)를 통해 응용 프로그램에로드되며, 이는 다시 응용 프로그램이 시작되는 동안 다시 application.run ()을 사용하여로드되는 루트 모듈을 사용하여로드됩니다.

응용 프로그램의 작업 흐름은 아래 다이어그램과 같이 나타낼 수 있습니다.

위의 다이어그램은 다음 단계에서 자세히 설명됩니다.

  • NativeScript 응용 프로그램이 시작되고 application.run () 메서드를 호출합니다.

  • application.run ()은 루트 모듈을 로드 합니다 .

  • 루트 모듈 은 아래 지정된 UI 구성 요소 중 하나를 사용하여 설계되었습니다.

    • Frame

    • TabView

    • SideDrawer

    • 모든 레이아웃보기

  • 프레임 구성 요소는 지정된 페이지 (페이지 모듈)를로드하고 렌더링됩니다. 다른 UI 구성 요소는 루트 모듈에 지정된대로 렌더링됩니다 . 다른 UI 구성 요소에는 페이지 모듈 을 기본 콘텐츠로 로드하는 옵션도 있습니다.

Angular 기반 NativeScript 응용 프로그램의 워크 플로

앞서 배운 것처럼 NativeScript 프레임 워크는 다양한 범주의 개발자를 수용 할 수있는 여러 방법론을 제공합니다. NativeScript에서 지원하는 방법론은 다음과 같습니다.

  • NativeScript Core − NativeScript Framework의 기본 또는 핵심 개념

  • Angular + NativeScript − 각도 기반 방법론

  • Vuejs + NativeScript − Vue.js 기반 방법론

Angular 프레임 워크가 NativeScript 프레임 워크에 어떻게 통합되는지 알아 보겠습니다.

1 단계

NativeScript는 Angular 애플리케이션을 부트 스트랩하기위한 객체 (platformNativeScriptDynamic)를 제공합니다. platformNativeScriptDynamic에는 애플리케이션을 시작하는 데 사용되는 bootstrapModule 메소드가 있습니다.

Angular 프레임 워크를 사용하여 응용 프로그램을 부트 스트랩하는 구문은 다음과 같습니다.

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

여기,

AppModule 루트 모듈입니다.

2 단계

앱 모듈의 간단한 구현 (지정된 코드 아래).

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

여기,

AppModuleAppComponent 구성 요소를로드하여 응용 프로그램을 시작합니다. Angular 구성 요소는 페이지와 유사하며 설계 및 프로그래밍 논리에 모두 사용됩니다.

AppComponent (app.component.ts)와 그 표현 로직 (app.component.css)의 간단한 구현은 다음과 같습니다.

app.component.ts

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

여기,

templateUrl 은 구성 요소의 디자인을 나타냅니다.

app.component.html

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

여기,

page-router-outlet Angular 응용 프로그램이 연결되는 위치입니다.

요약하면 Angular 프레임 워크는 약간의 차이가 있지만 NativeScript 프레임 워크와 유사한 모듈로 구성됩니다. Angular의 각 모듈에는 Angular 구성 요소와 라우터 설정 파일 (page-routing.mocdule.ts)이 있습니다. 라우터는 모듈별로 설정되며 탐색을 처리합니다. Angular 구성 요소는 NativeSctipt 코어의 페이지와 유사합니다.

각 구성 요소에는 UI 디자인 (page.component.html), 스타일 시트 (page.component.css) 및 JavaScript / TypeScript 코드 파일 (page.component.ts)이 있습니다.