NativeScript - Navigasi

Navigasi memungkinkan pengguna untuk dengan cepat menggeser ke layar yang mereka inginkan atau untuk menavigasi aplikasi atau untuk melakukan tindakan tertentu. Komponen navigasi membantu Anda mengimplementasikan navigasi menggunakan klik tombol sederhana ke pola yang lebih kompleks.

Navigasi sangat berbeda antara versi inti dan sudut dari NativeScript. Sementara navigasi kerangka inti adalah dasar untuk proses navigasi, model Angular NativeScript mengadopsi konsep navigasi inti dan memperluasnya agar kompatibel dengan kerangka kerja Angular.

Mari kita lihat konsep navigasi inti dan adopsi sudut dalam bab ini.

Konsep inti

Mari kita pahami cara kerja navigasi dalam NativeScript inti dalam bab ini.

Di NativeScript, navigasi dibagi menjadi empat kategori berbeda berdasarkan arah penerapannya seperti yang ditentukan di bawah -

  • Navigasi maju

  • Navigasi mundur

  • Navigasi lateral

  • Navigasi bawah

Navigasi Maju

Navigasi Maju mengacu pada menavigasi pengguna ke layar di tingkat hierarki berikutnya. Ini didasarkan pada dua komponen NativeScript,Frame dan Page.

Frame

Bingkai adalah komponen tingkat dasar untuk navigasi. Ini bukan wadah yang terlihat tetapi bertindak sebagai wadah untuk transisi antar halaman.

Contoh sederhananya adalah sebagai berikut -

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

Sini,

Frame menavigasi ke (atau memuat) komponen halaman halaman unggulan dan merendernya.

Page

Halaman berada di sebelah komponen Frame dan berfungsi sebagai wadah untuk komponen UI. Contoh sederhana dijelaskan di bawah -

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

Sini,

  • Awalnya, Halaman memuat semua komponen UI layar dan merendernya.

  • Saat pengguna mengklik tombol, pengguna akan diarahkan ke another-page halaman.

Navigasi Mundur

Metode navigasi mundur memungkinkan gerakan mundur melalui layar dalam satu aplikasi atau di berbagai aplikasi. Ini adalah arah berlawanan dari navigasi maju. Metode goBack () sederhana digunakan untuk menavigasi kembali ke halaman sebelumnya.

Ini didefinisikan di bawah -

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

Sini,

goBack() Metode akan dipicu saat pengguna mengetuk tombol. goBack() menavigasi pengguna ke halaman sebelumnya, jika tersedia.

Navigasi Lateral

Navigasi lateral mengacu pada navigasi antar layar pada tingkat hierarki yang sama. Ini didasarkan pada pola hub. Ini diaktifkan melalui komponen navigasi tertentu seperti BottomNavigation, Tabs, TabView, SideDrawer dan Modal View.

Contoh sederhana didefinisikan seperti di bawah ini -

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

Sini,

  • navigateToFeatured fungsi menggunakan metode navig () untuk menavigasi pengguna ke halaman unggulan.

  • Demikian pula, navigateToSearch Fungsi akan mengarahkan pengguna ke halaman pencarian.

Halaman hub juga dapat dicapai dengan menggunakan metode navigasi yang tersedia di layar halaman dan seseorang dapat keluar dari halaman hub menggunakan metode goBack ().

Contoh sederhananya adalah sebagai berikut -

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

Navigasi Bawah dan Tab

Gaya navigasi yang paling umum di aplikasi seluler adalah navigasi berbasis tab. Navigasi Tab diatur di bagian bawah layar atau di bagian atas di bawah header. Hal ini dicapai dengan menggunakan TabView dan BottomNavigation komponen.

Navigasi berbasis sudut

NativeScript memperluas konsep navigasinya untuk mengakomodasi konsep perutean Angular. NativeScript menyediakan modul baru, NativeScriptRouterModule dengan memperluas Angular RouterModule.

Konsep navigasi sudut NativeScript dapat dikategorikan menjadi beberapa bagian seperti di bawah ini -

  • halaman-router-outlet

  • nsRouterLink menarik

  • Kelas RouterExtension

  • Custom RouterReuseStrategy

Mari kita pelajari semua navigasi sudut di atas di bagian ini.

Outlet Router Halaman

Seperti yang dipelajari sebelumnya, page-router-outlet adalah pengganti dari outlet-router Angular. page-router-outlet membungkus Strategi Frame dan Page dari kerangka kerja navigasi inti Nativescript. Setiap halaman-router-outlet membuat komponen Frame baru dan setiap komponen yang dikonfigurasi di outlet akan dibungkus menggunakan komponen Halaman. Kemudian, metode navigasi asli digunakan untuk menavigasi ke halaman / rute lain.

Tautan Router (nsRouterLink)

nsRouterLink adalah pengganti dari RouterLink Angular. Ini memungkinkan komponen UI untuk ditautkan ke halaman lain menggunakan rute. nsRouterLink juga menyediakan dua opsi di bawah ini -

pageTransition- Digunakan untuk mengatur animasi transisi halaman. true memungkinkan transisi default. false menonaktifkan transisi. Nilai spesifik seperti slide, fadein, dll., Mengatur transisi tertentu.

clearHistory - true membersihkan riwayat navigasi nsRouterLink.

Kode contoh sederhana adalah sebagai berikut -

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

Ekstensi Router

NativeScript menyediakan kelas RouterExtensions dan memperlihatkan fungsi navigasi inti NativeScript.

Metode yang diekspos oleh RouterExtensions adalah sebagai berikut -

  • navigate

  • navigateByUrl

  • back

  • canGoBack

  • backToPreviousPage

  • canGoBackToPreviousPage

Contoh kode sederhana menggunakan RouterExtensions adalah sebagai berikut -

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

Strategi Penggunaan Ulang Rute Kustom

NativeScript menggunakan strategi penggunaan ulang rute kustom (RouterReuseStrategy) untuk mengakomodasi arsitektur aplikasi seluler. Aplikasi seluler berbeda dalam aspek-aspek tertentu dibandingkan dengan aplikasi web.

Misalnya, halaman dapat dihancurkan dalam aplikasi web saat pengguna keluar dari halaman dan membuatnya kembali saat pengguna menavigasi ke halaman. Namun, dalam aplikasi seluler, halaman tersebut akan dipertahankan dan digunakan kembali. Konsep-konsep ini dipertimbangkan saat merancang konsep perutean.

Rute

Modul perutean sederhana dalam aplikasi NativeScript Angular adalah seperti di bawah ini -

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

Sini,

Modul perutean sangat mirip dengan versi Angular kecuali sangat sedikit pengecualian. Pada kenyataannya, NativeScript menggunakan strategi navigasi intinya dengan memaparkannya dengan cara yang mirip dengan kerangka kerja Angular.