कोणीय 4 - रूटिंग
रूटिंग मूल रूप से पृष्ठों के बीच नेविगेट करने का मतलब है। आपने कई साइटों को लिंक के साथ देखा है जो आपको एक नए पृष्ठ पर ले जाते हैं। यह रूटिंग का उपयोग करके प्राप्त किया जा सकता है। यहां हम जिन पृष्ठों का उल्लेख कर रहे हैं, वे घटक के रूप में होंगे। हमने पहले ही देखा है कि एक घटक कैसे बनाया जाए। आइए अब एक घटक बनाते हैं और देखें कि इसके साथ रूटिंग का उपयोग कैसे करें।
मुख्य मूल घटक में 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।
जब कोई उपयोगकर्ता नया घटक क्लिक करता है, तो पृष्ठ ताज़ा नहीं होता है और सामग्री को बिना किसी लोड किए उपयोगकर्ता को दिखाया जाता है। क्लिक करने पर साइट कोड का केवल एक विशेष टुकड़ा पुनः लोड किया जाएगा। यह सुविधा तब मदद करती है जब हमारे पास पृष्ठ पर भारी सामग्री होती है और उपयोगकर्ता इंटरैक्शन के आधार पर लोड करने की आवश्यकता होती है। सुविधा भी एक अच्छा उपयोगकर्ता अनुभव देती है क्योंकि पृष्ठ पुनः लोड नहीं किया जाता है।