नेटिवस्क्रिप्ट - नेविगेशन
नेविगेशन उपयोगकर्ताओं को अपनी वांछित स्क्रीन पर जल्दी से स्वाइप करने या ऐप के माध्यम से नेविगेट करने या किसी विशेष कार्य को करने में सक्षम बनाता है। नेविगेशन घटक आपको सरल बटन क्लिकों को और अधिक जटिल पैटर्न का उपयोग करके नेविगेशन को लागू करने में मदद करता है।
नेविगेशन मूल निवासी और मूल निवासी संस्करण के बीच पर्याप्त रूप से भिन्न होता है। जबकि कोर फ्रेमवर्क नेविगेशन नेविगेशन प्रक्रिया के लिए नींव है, नेटिवस्क्रिप्ट का कोणीय मॉडल कोर नेविगेशन अवधारणा को अपनाता है और इसे कोणीय ढांचे के साथ संगत बनाने के लिए विस्तारित करता है।
आइए हम इस अध्याय में मुख्य नेविगेशन अवधारणा और नेविगेशन के कोणीय अपनाने दोनों को देखें।
मूल अवधारणा
आइए समझते हैं कि इस अध्याय में कोर नेटिवस्क्रिप्ट में नेविगेशन कैसे काम करता है।
NativeScript में, नेविगेशन चार अलग-अलग श्रेणियों में विभाजित होता है, जो नीचे दिए गए निर्देशों के अनुसार लागू होता है -
आगे का नेविगेशन
बैकवर्ड नेविगेशन
पार्श्व नेविगेशन
नीचे का नेविगेशन
आगे का नेविगेशन
फ़ॉरवर्ड नेविगेशन का तात्पर्य अगले स्तर के पदानुक्रम में उपयोगकर्ताओं को स्क्रीन पर नेविगेट करने से है। यह दो नेटिवस्क्रिप्ट घटकों पर आधारित है,Frame तथा Page.
Frame
फ़्रेम नेविगेशन के लिए मूल स्तर का घटक है। यह एक दृश्यमान कंटेनर नहीं है, लेकिन पृष्ठों के बीच संक्रमण के लिए एक कंटेनर के रूप में कार्य करता है।
एक सरल उदाहरण इस प्रकार है -
<Frame id="featured" defaultPage="featured-page" />
यहाँ,
फ़्रेम पृष्ठ-पृष्ठ पृष्ठ घटक को (या लोड) करता है और उसे रेंडर करता है।
Page
पृष्ठ फ़्रेम घटक के बगल में है और यह UI घटक के लिए एक कंटेनर के रूप में कार्य करता है। सरल उदाहरण नीचे परिभाषित किया गया है -
<Page loaded="onPageLoaded">
<ActionBar title="Item" class="action-bar"></ActionBar>
<AbsoluteLayout>
<Label text="Label"/<
<Button text="navigate('another-page')" tap="onTap"/>
</AbsoluteLayout>
</Page>
यहाँ,
प्रारंभ में, पृष्ठ स्क्रीन के सभी UI घटक को लोड करता है और इसे रेंडर करता है।
जब उपयोगकर्ता बटन पर क्लिक करता है, तो यह उपयोगकर्ता को नेविगेट करेगा another-page पृष्ठ।
बैकवर्ड नेविगेशन
बैकवर्ड नेविगेशन विधि एक ऐप के भीतर या विभिन्न ऐप में स्क्रीन के माध्यम से बैकवर्ड आंदोलन को सक्षम बनाता है। यह फॉरवर्ड नेविगेशन की विपरीत दिशा है। पिछले पृष्ठ पर वापस जाने के लिए सरल goBack () विधि का उपयोग किया जाता है।
यह नीचे परिभाषित किया गया है -
<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>
यहाँ,
goBack() उपयोगकर्ता द्वारा बटन टैप करने पर विधि चालू हो जाएगी। goBack() यदि उपलब्ध है, तो उपयोगकर्ताओं को पिछले पृष्ठ पर नेविगेट करता है।
पार्श्व नेविगेशन
पार्श्व नेविगेशन समान रूप से पदानुक्रम के स्क्रीन के बीच के नेविगेशन को संदर्भित करता है। यह हब पैटर्न पर आधारित है। यह विशिष्ट नेविगेशन घटकों जैसे कि बोटनैविगेशन, टैब्स, टैब व्यू, साइडड्रावर और मोडल व्यू के माध्यम से सक्षम है।
एक सरल उदाहरण नीचे दिया गया है -
<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>
यहाँ,
navigateToFeatured फ़ंक्शन उपयोगकर्ता को विशेष रुप से पृष्ठ पर नेविगेट करने के लिए नेविगेट () विधि का उपयोग करता है।
इसी तरह, navigateToSearch फ़ंक्शन उपयोगकर्ता को खोज पृष्ठ पर नेविगेट करेगा।
हब पेज पेज स्क्रीन में उपलब्ध नेविगेट विधि का उपयोग करके भी पहुँचा जा सकता है और एक हब पेज से बाहर जा सकता है।
एक सरल उदाहरण इस प्रकार है -
<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>
नीचे और टैब नेविगेशन
मोबाइल ऐप्स में नेविगेशन की सबसे आम शैली टैब-आधारित नेविगेशन है। टैब नेविगेशन को स्क्रीन के नीचे या शीर्ष लेख के नीचे शीर्ष पर व्यवस्थित किया जाता है। यह TabView और निचला स्तर घटक का उपयोग करके प्राप्त किया जाता है ।
कोणीय आधारित नेविगेशन
नेटिवस्क्रिप्ट एंगुलर रूटिंग अवधारणा को समायोजित करने के लिए अपनी नेविगेशन अवधारणा का विस्तार करता है। NativeScript, Angular RouterModule का विस्तार करके एक नया मॉड्यूल, NativeScriptRouterModule प्रदान करता है।
नेटिवस्क्रिप्ट कोणीय नेविगेशन अवधारणा को नीचे दिए गए अनुभाग में वर्गीकृत किया जा सकता है -
पेज-राउटर-आउटलेट टैग
nsRouterLink आकर्षक
राउटरटेक्स्ट क्लास
कस्टम RouterReuseStrategy
आइए हम इस खंड में उपरोक्त सभी कोणीय नेविगेशन सीखें।
पेज राउटर आउटलेट
जैसा कि पहले सीखा गया था, पेज-राउटर-आउटलेट, एंगुलर के राउटर-आउटलेट का प्रतिस्थापन है। पेज-राउटर-आउटलेट नैटस्क्रिप्ट कोर नेविगेशन फ्रेमवर्क की फ़्रेम और पेज रणनीति को लपेटता है। प्रत्येक पृष्ठ-राउटर-आउटलेट एक नया फ़्रेम घटक बनाता है और आउटलेट में प्रत्येक कॉन्फ़िगर किए गए घटकों को पेज घटक का उपयोग करके लपेटा जाएगा। फिर, अन्य पेज / रूट पर नेविगेट करने के लिए देशी नेविगेट विधि का उपयोग किया जाता है।
राउटर लिंक (nsRouterLink)
nsRouterLink, Angular's RouterLink का प्रतिस्थापन है। यह यूआई घटक को मार्ग का उपयोग करके दूसरे पृष्ठ से लिंक करने में सक्षम बनाता है। nsRouterLink भी नीचे दो विकल्प प्रदान करता है -
pageTransition- इसका उपयोग पेज ट्रांजीशन एनीमेशन सेट करने के लिए किया जाता है। सच डिफ़ॉल्ट संक्रमण सक्षम बनाता है। गलत संक्रमण को निष्क्रिय करता है। स्लाइड, फैडिन, आदि जैसे विशिष्ट मूल्य, विशेष संक्रमण निर्धारित करते हैं।
clearHistory - nsRouterLink का नेविगेशन इतिहास सही है।
एक सरल उदाहरण कोड इस प्रकार है -
<Button text="Go to Home" [nsRouterLink]="['/home']"
pageTransition="slide" clearHistory="true"></Button>
राउटर एक्सटेंशन
नेटिवस्क्रिप्ट RouterExtensions क्लास प्रदान करता है और कोर नेटिवस्क्रिप्ट के नेविगेशन फ़ंक्शन को उजागर करता है।
RouterExtensions द्वारा उजागर तरीके निम्नानुसार हैं -
navigate
navigateByUrl
back
canGoBack
backToPreviousPage
canGoBackToPreviousPage
RouterExtensions का उपयोग करते हुए एक सरल उदाहरण कोड निम्नानुसार है -
import { RouterExtensions } from "nativescript-angular/router";
@Component({
// ...
})
export class HomeComponent {
constructor(private routerExtensions: RouterExtensions) { }
}
कस्टम मार्ग पुन: उपयोग की रणनीति
नेटिवस्क्रिप्ट एक मोबाइल एप्लिकेशन की वास्तुकला को समायोजित करने के लिए एक कस्टम मार्ग पुन: उपयोग की रणनीति (RouterReuseStrategy) का उपयोग करता है। वेब एप्लिकेशन की तुलना में एक मोबाइल एप्लिकेशन कुछ पहलुओं में भिन्न होता है।
उदाहरण के लिए, पृष्ठ को वेब अनुप्रयोग में तब नष्ट किया जा सकता है जब उपयोगकर्ता पृष्ठ से दूर हो जाता है और उपयोगकर्ता द्वारा पृष्ठ पर नेविगेट करने पर इसे पुनः बनाया जाता है। लेकिन, मोबाइल एप्लिकेशन में, पृष्ठ संरक्षित और पुन: उपयोग किया जाएगा। रूटिंग अवधारणा को डिजाइन करते समय इन अवधारणाओं को ध्यान में रखा जाता है।
मार्गों
NativeScript Angular एप्लीकेशन में एक साधारण राउटिंग मॉड्यूल निम्नानुसार होगा -
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 { }
यहाँ,
रूटिंग मॉड्यूल बहुत कम अपवादों को छोड़कर कोणीय संस्करण के समान है। वास्तव में, मूल निवासी अपनी मूल नेविगेशन रणनीति का उपयोग इसे एक तरह से कोणीय ढांचे के समान उजागर करके करता है।