नेटिवस्क्रिप्ट - आर्किटेक्चर

नेटिवस्क्रिप्ट मोबाइल एप्लिकेशन बनाने के लिए एक उन्नत ढांचा है। यह मोबाइल एप्लिकेशन बनाने की जटिलता को छुपाता है और अत्यधिक अनुकूलित और उन्नत मोबाइल एप्लिकेशन बनाने के लिए एक साधारण एपीआई को उजागर करता है। नेटिवस्क्रिप्ट Android और iOS दोनों में आसानी से मोबाइल एप्लिकेशन बनाने के लिए एंट्री लेवल डेवलपर्स को भी सक्षम बनाता है।

आइए इस अध्याय में NativeScript फ्रेमवर्क की वास्तुकला को समझते हैं।

परिचय

NativeScript फ्रेमवर्क की मुख्य अवधारणा हाइब्रिड स्टाइल मोबाइल एप्लिकेशन बनाने के लिए डेवलपर को सक्षम करना है। हाइब्रिड एप्लिकेशन एक सामान्य मोबाइल एप्लिकेशन के अंदर वेब एप्लिकेशन को होस्ट करने के लिए प्लेटफ़ॉर्म विशिष्ट ब्राउज़र एपीआई का उपयोग करता है और जावास्क्रिप्ट एपीआई के माध्यम से एप्लिकेशन तक सिस्टम पहुंच प्रदान करता है।

नेटिवस्क्रिप्ट बहुत अधिक निवेश करता है JavaScript languageडेवलपर्स के लिए एक कुशल ढांचा प्रदान करने के लिए। जबसेJavaScriptक्लाइंट साइड प्रोग्रामिंग (वेब ​​डेवलपमेंट) के लिए डी-फैक्टो मानक है और हर डेवलपर को जावास्क्रिप्ट भाषा की अच्छी जानकारी होती है, यह डेवलपर्स को नेटिवस्क्रिप्ट फ्रेमवर्क में आसानी से प्रवेश करने में मदद करता है। निम्न स्तर पर, नेटिवस्क्रिप्ट नेटिव एपीआई को जावास्क्रिप्ट प्लगइन्स के संग्रह के माध्यम से उजागर करता हैNative plugins.

नेटिवस्क्रिप्ट नेटिव प्लगइन्स की नींव पर बनाता है और जावास्क्रिप्ट मॉड्यूल का उपयोग करने के लिए कई उच्च स्तर और आसान प्रदान करता है । प्रत्येक मॉड्यूल एक विशिष्ट कार्यक्षमता करता है जैसे कैमरा एक्सेस करना, स्क्रीन डिजाइन करना आदि, इन सभी मॉड्यूलों को एक जटिल मोबाइल एप्लिकेशन को आर्किटेक्ट करने के लिए कई तरीकों से जोड़ा जा सकता है।

नीचे आरेख NativeScript फ्रेमवर्क के उच्च स्तरीय अवलोकन को दर्शाता है -

NativeScript Application - नेटिवस्क्रिप्ट फ्रेमवर्क डेवलपर को या तो कोणीय शैली के अनुप्रयोग या वीयू स्टाइल एप्लिकेशन का उपयोग करने की अनुमति देता है।

JavaScript Modules - नेटिवस्क्रिप्ट ढांचे में यूआई मॉड्यूल, एप्लिकेशन मॉड्यूल, कोर मॉड्यूल आदि के रूप में स्पष्ट रूप से वर्गीकृत जावास्क्रिप्ट मॉड्यूल का एक समृद्ध सेट प्रदान करता है। किसी भी स्तर के जटिल आवेदन को लिखने के लिए सभी मॉड्यूल को किसी भी समय आवेदन द्वारा एक्सेस किया जा सकता है।

JavaScript plugins- NativeScript फ्रेमवर्क प्लेटफ़ॉर्म संबंधित कार्यक्षमता तक पहुंचने के लिए जावास्क्रिप्ट प्लगइन्स का एक बड़ा संग्रह प्रदान करता है। मॉड्यूल प्लेटफ़ॉर्म विशिष्ट कार्यक्षमता प्रदान करने के लिए जावास्क्रिप्ट प्लगइन्स का उपयोग करता है।

Native plugins- नेटिव प्लग इन को प्लेटफॉर्म स्पेसिफिक लैंग्वेज में लिखा जाता है ताकि सिस्टम फंक्शनैलिटी को रैपर किया जा सके जो आगे जावास्क्रिप्ट प्लगइन द्वारा उपयोग किया जाएगा।

Platform API - प्लेटफॉर्म विक्रेताओं द्वारा उपलब्ध कराई गई एपीआई।

संक्षेप में, नेटिवस्क्रिप्ट एप्लिकेशन को मॉड्यूल का उपयोग करके लिखा और व्यवस्थित किया जाता है। मॉड्यूल शुद्ध जावास्क्रिप्ट में लिखे गए हैं और मॉड्यूल प्‍लग इन के माध्‍यम से प्‍लेटफॉर्म संबंधी कार्यक्षमता (जब भी जरूरत होती है) तक पहुंचते हैं और अंत में प्‍लग इन प्‍लेटफॉर्म API और JavaScript API को ब्रिज करते हैं।

एक नेटिवस्क्रिप्ट एप्लिकेशन का वर्कफ़्लो

जैसा कि हमने पहले सीखा, नेटिवस्क्रिप्ट एप्लिकेशन मॉड्यूल से बना है। प्रत्येक और प्रत्येक मॉड्यूल एक विशिष्ट सुविधा को सक्षम करता है। NativeScript एप्लिकेशन को बूटस्ट्रैप करने के लिए मॉड्यूल की दो महत्वपूर्ण श्रेणियां इस प्रकार हैं -

  • रूट मॉड्यूल

  • पेज मॉड्यूल

रूट और पेज मॉड्यूल को एप्लिकेशन मॉड्यूल के रूप में वर्गीकृत किया जा सकता है। एप्लिकेशन मॉड्यूल नेटिवस्क्रिप्ट एप्लिकेशन का प्रवेश बिंदु है। यह एक पेज को बूटस्ट्रैप करता है, डेवलपर को पेज का यूजर इंटरफेस बनाने में सक्षम बनाता है और अंत में पेज के बिजनेस लॉजिक को निष्पादित करने की अनुमति देता है। एक एप्लिकेशन मॉड्यूल में तीन आइटम शामिल हैं -

  • उपयोगकर्ता इंटरफ़ेस डिज़ाइन को XML में कोडित किया गया है (उदाहरण के लिए page.xml / page.component.html)

  • CSS में कोडित शैलियाँ (उदाहरण के लिए page.css / page.component.css)

  • जावास्क्रिप्ट में मॉड्यूल के वास्तविक व्यापार तर्क (उदाहरण के लिए page.js / page.component.ts)

नेटिवस्क्रिप्ट एप्लिकेशन पृष्ठ को डिजाइन करने के लिए बहुत सारे यूआई घटक (यूआई मॉड्यूल के तहत) प्रदान करता है। यूआई घटक को XML प्रारूप या HTML प्रारूप में कोणीय आधारित अनुप्रयोग में दर्शाया जा सकता है। अनुप्रयोग मॉड्यूल पृष्ठ को डिज़ाइन करने के लिए UI का उपयोग करता है और डिज़ाइन को अलग XML, page.xml / page.component.html में संग्रहीत करता है । मानक CSS का उपयोग करके डिज़ाइन को स्टाइल किया जा सकता है।

एप्लिकेशन मॉड्यूल अलग सीएसएस में डिजाइन की शैली को स्टोर करता है, page.css / page.component.css। पृष्ठ की कार्यक्षमता जावास्क्रिप्ट / टाइपस्क्रिप्ट का उपयोग करके की जा सकती है, जिसमें डिज़ाइन के साथ-साथ प्लेटफ़ॉर्म सुविधाओं तक पूरी पहुंच है। एप्लिकेशन मॉड्यूल पेज की वास्तविक कार्यक्षमता को कोड करने के लिए एक अलग फाइल, पेज.जेएस / पेज.कॉमपेंटेंट.ट्स का उपयोग करता है।

रूट मॉड्यूल

नेटिवस्क्रिप्ट यूआई कंटेनरों के माध्यम से उपयोगकर्ता इंटरफ़ेस और उपयोगकर्ता इंटरैक्शन का प्रबंधन करता है। प्रत्येक UI कंटेनर में एक रूट मॉड्यूल होना चाहिए और जिसके माध्यम से UI कंटेनर UI का प्रबंधन करता है। नेटिवस्क्रिप्ट एप्लिकेशन में दो प्रकार के यूआई कंटेनर हैं -

Application Container- प्रत्येक NativeScript एप्लिकेशन में एक एप्लिकेशन कंटेनर होना चाहिए और इसे application.run () विधि का उपयोग करके सेट किया जाएगा। यह एप्लिकेशन के UI को इनिशियलाइज़ करता है।

Model View Container- नेटिवस्क्रिप्ट मॉडल दृश्य कंटेनर का उपयोग करके मोडल संवादों का प्रबंधन करता है। एक नेटिवस्क्रिप्ट एप्लिकेशन में मॉडल व्यू कंटेनर की कोई भी संख्या हो सकती है।

हर रूट मॉड्यूल की सामग्री के रूप में केवल एक UI घटक होना चाहिए। बदले में यूआई घटक अपने बच्चों के रूप में अन्य यूआई घटक रख सकते हैं। नेटिवस्क्रिप्ट बच्चे की सुविधा के साथ बहुत सारे यूआई घटक जैसे कि टैब व्यू, स्क्रोल व्यू इत्यादि प्रदान करता है। हम रूट यूआई घटक के रूप में इनका उपयोग कर सकते हैं। एक अपवाद फ़्रेम है , जिसमें बच्चे का विकल्प नहीं है लेकिन रूट घटक के रूप में इस्तेमाल किया जा सकता है। फ़्रेम पेज मॉड्यूल को लोड करने के लिए विकल्प प्रदान करता है और अन्य पेज मॉड्यूल पर भी नेविगेट करने के लिए विकल्प प्रदान करता है ।

पेज मॉड्यूल

नेटिवस्क्रिप्ट में, प्रत्येक और प्रत्येक पृष्ठ मूल रूप से एक पृष्ठ मॉड्यूल है । पृष्ठ मॉड्यूल NativeScript द्वारा प्रदान की गई UI घटकों के समृद्ध सेट का उपयोग करके बनाया गया है। पृष्ठ मॉड्यूल लोड किए गए हैं फ़्रेम घटक के माध्यम से आवेदन (इसकी डिफ़ॉल्टपेज विशेषता या नेविगेट () विधि का उपयोग करके), जो बदले में रूट मॉड्यूल का उपयोग करके लोड किया जाता है , जो फिर से आवेदन शुरू होने पर आवेदन (।) का उपयोग करके लोड किया जाता है।

आवेदन के कार्य प्रवाह को निम्न आरेख के रूप में दर्शाया जा सकता है -

उपरोक्त आरेख को निम्नलिखित चरणों में विस्तार से बताया गया है -

  • NativeScript अनुप्रयोग शुरू होता है और application.run () विधि को कॉल करता है।

  • application.run () एक रूट मॉड्यूल लोड करता है ।

  • रूट मॉड्यूल नीचे निर्दिष्ट के रूप में यूआई घटक में से किसी एक का उपयोग करके बनाया गया है -

    • Frame

    • TabView

    • SideDrawer

    • कोई भी लेआउट दृश्य

  • फ़्रेम घटक निर्दिष्ट पृष्ठ (पृष्ठ मॉड्यूल) को लोड करता है और प्रदान करता है। रूट मॉड्यूल में निर्दिष्ट के रूप में अन्य यूआई घटकों को प्रदान किया जाएगा । अन्य UI घटक में पृष्ठ मॉड्यूल को इसकी मुख्य सामग्री के रूप में लोड करने का विकल्प भी है ।

एंगुलर आधारित नेटिवस्क्रिप्ट एप्लिकेशन का वर्कफ़्लो

जैसा कि हमने पहले सीखा, नेटिवस्क्रिप्ट फ्रेमवर्क विभिन्न डेवलपर्स की श्रेणी को पूरा करने के लिए कई तरीके प्रदान करता है। नेटिवस्क्रिप्ट द्वारा समर्थित कार्यप्रणाली इस प्रकार हैं -

  • NativeScript Core - नेटिवस्क्रिप्ट फ्रेमवर्क की मूल या मूल अवधारणा

  • Angular + NativeScript - कोणीय आधारित कार्यप्रणाली

  • Vuejs + NativeScript - Vue.js आधारित कार्यप्रणाली

आइए जानें कि एनरिकुलर फ्रेमवर्क में कोणीय ढांचे को कैसे शामिल किया जाता है।

चरण 1

NativeScript एंगुलर एप्लिकेशन को बूटस्ट्रैप करने के लिए ऑब्जेक्ट (platformNativeScriptDynamic) प्रदान करता है। platformNativeScriptDynamic में एक विधि है, bootstrapModule, जिसका उपयोग एप्लिकेशन को शुरू करने के लिए किया जाता है।

एंगुलर फ्रेमवर्क का उपयोग करके एप्लिकेशन को बूटस्ट्रैप करने का सिंटैक्स इस प्रकार है -

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 घटक लोड करके अनुप्रयोग प्रारंभ करता है। कोणीय घटक पृष्ठों के समान हैं और डिजाइन और प्रोग्रामिंग तर्क दोनों के लिए उपयोग किए जाते हैं।

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 वह स्थान है जहाँ कोणीय अनुप्रयोग जुड़ा हुआ है।

सारांश में, कोणीय रूपरेखा मामूली अंतर के साथ नेटिवस्क्रिप्ट ढांचे के समान मॉड्यूल से बना है। एंगुलर के प्रत्येक मॉड्यूल में एक कोणीय घटक और एक राउटर सेटअप फ़ाइल (पृष्ठ- routing.mocdule.ts) होगी। राउटर प्रति मॉड्यूल सेट है और यह नेविगेशन का ख्याल रखता है। कोणीय घटक NativeSctipt कोर के पृष्ठों के अनुरूप होते हैं।

प्रत्येक घटक में एक यूआई डिज़ाइन (page.component.html), एक स्टाइल शीट (page.component.css), और एक जावास्क्रिप्ट / टाइपस्क्रिप्ट कोड फ़ाइल (page.component.ts) होगी।