कोणीय 6 - रूटिंग

रूटिंग मूल रूप से पृष्ठों के बीच नेविगेट करने का मतलब है। आपने कई साइटों को लिंक के साथ देखा है जो आपको एक नए पृष्ठ पर ले जाती हैं। यह रूटिंग का उपयोग करके प्राप्त किया जा सकता है। यहां हम जिन पृष्ठों का उल्लेख कर रहे हैं, वे घटक के रूप में होंगे। हमने पहले ही देखा है कि एक घटक कैसे बनाया जाए। आइए अब एक घटक बनाते हैं और देखें कि इसके साथ रूटिंग का उपयोग कैसे करें।

मुख्य मूल घटक में app.module.ts, हमें अब राउटर मॉड्यूल शामिल करना होगा जैसा कि नीचे दिखाया गया है -

import { BrowserModule } from '@angular/platform-browser';
import { NgModule } from '@angular/core';
import { RouterModule} from '@angular/router';
import { AppComponent } from './app.component';
import { NewCmpComponent } from './new-cmp/new-cmp.component';
import { ChangeTextDirective } from './change-text.directive';
import { SqrtPipe } from './app.sqrt';
@NgModule({
   declarations: [
      SqrtPipe,
      AppComponent,
      NewCmpComponent,
      ChangeTextDirective
   ],
   imports: [
      BrowserModule,
      RouterModule.forRoot([
         {
            path: 'new-cmp',
            component: NewCmpComponent
         }
      ])
   ],
   providers: [],
   bootstrap: [AppComponent]
})
export class AppModule { }

'@ कोणीय / राउटर' से {RouterModule} आयात करें

यहाँ, RouterModule कोणीय / राउटर से आयात किया जाता है। मॉड्यूल नीचे दिखाए अनुसार आयात में शामिल है -

RouterModule.forRoot([
   {
      path: 'new-cmp',
      component: NewCmpComponent
   }
])

RouterModule को संदर्भित करता है forRootजो एक सरणी के रूप में एक इनपुट लेता है, जो बदले में पथ और घटक की वस्तु है। पाथ राउटर का नाम है और कंपोनेंट क्लास का नाम है, यानी बनाया गया कंपोनेंट।

आइये अब घटक निर्मित फाइल देखते हैं -

नई cmp.component.ts

import { Component, OnInit } from '@angular/core';
@Component({
   selector: 'app-new-cmp',
   templateUrl: './new-cmp.component.html',
   styleUrls: ['./new-cmp.component.css']
})
export class NewCmpComponent implements OnInit {
   newcomponent = "Entered in new component created";
   constructor() {}
   ngOnInit() { }
}

मुख्य मॉड्यूल के आयात में हाइलाइट किए गए वर्ग का उल्लेख किया गया है।

नई cmp.component.html

<p>
   {{newcomponent}}
</p>

<p>
   new-cmp works!
</p>

अब, जब भी आवश्यक हो या मुख्य मॉड्यूल से क्लिक किया जाए, तो हमें HTML फ़ाइल से उपरोक्त सामग्री की आवश्यकता होती है। इसके लिए, हमें राउटर विवरण को इसमें जोड़ना होगाapp.component.html

<h1>Custom Pipe</h1>
<b>Square root of 25 is: {{25 | sqrt}}</b><br/>
<b>Square root of 729 is: {{729 | sqrt}}</b>
<br />
<br />
<br />
<a routerLink = "new-cmp">New component</a>
<br />
<br/>
<router-outlet></router-outlet>

उपरोक्त कोड में, हमने एंकर लिंक टैग बनाया है और राउटरलिंक दिया है "new-cmp"। इसमें संदर्भित हैapp.module.ts पथ के रूप में।

जब कोई उपयोगकर्ता क्लिक करता है new component, पृष्ठ को सामग्री प्रदर्शित करनी चाहिए। इसके लिए हमें निम्नलिखित टैग की आवश्यकता है -<router-outlet> </router-outlet>

उपरोक्त टैग यह सुनिश्चित करता है कि सामग्री इसमें है new-cmp.component.html उपयोगकर्ता द्वारा क्लिक करने पर पृष्ठ पर प्रदर्शित किया जाएगा new component

आइए अब देखते हैं कि ब्राउज़र पर आउटपुट कैसे प्रदर्शित होता है।

जब कोई उपयोगकर्ता नए घटक पर क्लिक करता है, तो आप ब्राउज़र में निम्नलिखित देखेंगे।

Url समाहित है http://localhost:4200/new-cmp। यहां, नए-सीएमपी को मूल यूआरएल में जोड़ा जाता है, जो कि इसमें दिया गया मार्ग हैapp.module.ts और में राउटर-लिंक app.component.html

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