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

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

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

app.module.ts

import { BrowserModule } from '@angular/platform-browser'; 
import { NgModule } from '@angular/core';
import { AppRoutingModule } from './app-routing.module'; 
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, 
      AppRoutingModule 
   ], 
   providers: [], 
   bootstrap: [AppComponent] 
})
export class AppModule { }

AppRoutingModule जैसा कि ऊपर दिखाया गया है और आयात सरणी में शामिल है।

का फाइल विवरण app-routing.module नीचे दिए गए हैं -

import { NgModule } from '@angular/core'; 
import { Routes, RouterModule } from '@angular/router';

const routes: Routes = [];
@NgModule({ 
   imports: [
      RouterModule.forRoot(routes)
   ],
   exports: [RouterModule] 
}) 
export class AppRoutingModule { }

यहां, हमें यह ध्यान रखना होगा कि प्रोजेक्ट सेटअप के दौरान रूटिंग को जोड़ने पर यह फ़ाइल डिफ़ॉल्ट रूप से जेनरेट होती है। यदि नहीं जोड़ा गया है, तो उपरोक्त फ़ाइलों को मैन्युअल रूप से जोड़ना होगा।

इसलिए उपरोक्त फ़ाइल में, हमने @ कोणीय / राउटर से रूट और राउटरमॉडल आयात किया है।

कांस्टेबल है routesपरिभाषित जो रूट प्रकार का है। यह एक ऐसा सरणी है जो हमारी परियोजना में हमारे लिए आवश्यक सभी मार्गों को रखती है।

कांस्टेबल राऊटरमॉडुले को दिए गए हैं जैसा कि @NgModule में दिखाया गया है। उपयोगकर्ता को रूटिंग विवरण प्रदर्शित करने के लिए, हमें <रूटर-आउटलेट> निर्देश जोड़ना होगा जहां हम चाहते हैं कि दृश्य प्रदर्शित हो।

जैसा कि नीचे दिखाया गया है उसी में app.component.html में जोड़ा गया है

<h1>Angular 7 Routing Demo</h1> 
<router-outlet></router-outlet>

अब हम 2 घटक बनाते हैं जिन्हें कहा जाता है Home तथा Contact Us और रूटिंग का उपयोग करके उनके बीच नेविगेट करें।

घटक गृह

सबसे पहले, हम होम के बारे में चर्चा करेंगे। घटक होम के लिए वाक्य रचना निम्नलिखित है -

ng g component home
C:\projectA7\angular7-app>ng g component home CREATE 
src/app/home/home.component.html (23 bytes) CREATE 
src/app/home/home.component.spec.ts (614 bytes) CREATE 
src/app/home/home.component.ts (261 bytes) CREATE 
src/app/home/home.component.css (0 bytes) UPDATE 
src/app/app.module.ts (692 bytes)

घटक हमसे संपर्क करें

घटक हमसे संपर्क करने के लिए वाक्यविन्यास निम्नलिखित है -

ng g component contactus
C:\projectA7\angular7-app>ng g component contactus 
CREATE src/app/contactus/contactus.component.html (28 bytes) 
CREATE src/app/contactus/contactus.component.spec.ts (649 bytes) 
CREATE src/app/contactus/contactus.component.ts (281 bytes) 
CREATE src/app/contactus/contactus.component.css (0 bytes) 
UPDATE src/app/app.module.ts (786 bytes)

हम घर बनाने और हमसे संपर्क करने के लिए किए जाते हैं। नीचे app.module.ts में घटकों का विवरण दिया गया है -

import { BrowserModule } from '@angular/platform-browser'; 
import { NgModule } from '@angular/core';
import { AppRoutingModule } from './app-routing.module'; 
import { AppComponent } from './app.component'; 
import { NewCmpComponent } from './new-cmp/new-cmp.component'; 
import { ChangeTextDirective } from './change-text.directive'; 
import { SqrtPipe } from './app.sqrt'; 
import { HomeComponent } from './home/home.component'; 
import { ContactusComponent } from './contactus/contactus.component';

@NgModule({ 
   declarations: [ 
      SqrtPipe, 
      AppComponent, 
      NewCmpComponent, 
      ChangeTextDirective, 
      HomeComponent, 
      ContactusComponent 
   ],
   imports: [ 
      BrowserModule, 
      AppRoutingModule 
   ],
   providers: [], 
   bootstrap: [AppComponent] 
}) 
export class AppModule { }

अब हम मार्गों का विवरण जोड़ते हैं app-routing.module.ts नीचे दिखाया गया है -

import { NgModule } from '@angular/core'; 
import { Routes, RouterModule } from '@angular/router'; 
import { HomeComponent } from './home/home.component'; 
import { ContactusComponent } from './contactus/contactus.component';

const routes: Routes = [ 
   {path:"home", component:HomeComponent}, 
   {path:"contactus", component:ContactusComponent} 
];
@NgModule({ 
   imports: [RouterModule.forRoot(routes)], 
   exports: [RouterModule] 
})
export class AppRoutingModule { }

मार्ग सरणी में पथ और घटक के साथ घटक विवरण है। ऊपर दिखाए गए अनुसार आवश्यक घटक आयात किया जाता है।

यहां, हमें यह ध्यान देने की आवश्यकता है कि राउटिंग के लिए हमें जिन घटकों की आवश्यकता है, उन्हें app.module.ts में और एप्लिकेशन- routing.module.ts में भी आयात किया जाए। आइए हम उन्हें एक स्थान पर आयात करते हैं, अर्थात, app-routing.module.ts में।

इसलिए हम राउटिंग के लिए उपयोग किए जाने वाले घटक की एक सरणी बनाएंगे और सरणी को ऐप-राउटिंग.module.ts में निर्यात करेंगे और फिर से इसे app.module.ts में आयात करेंगे। इसलिए हमारे पास ऐप-राउटिंग.module.ts में रूटिंग के लिए उपयोग किए जाने वाले सभी घटक हैं।

ऐसा हमने किया है app-routing.module.ts -

import { NgModule } from '@angular/core'; 
import { Routes, RouterModule } from '@angular/router'; 
import { HomeComponent } from './home/home.component'; 
import { ContactusComponent } from './contactus/contactus.component'; 

const routes: Routes = [
   {path:"home", component:HomeComponent},
   {path:"contactus", component:ContactusComponent} 
];
@NgModule({
   imports: [RouterModule.forRoot(routes)], 
   exports: [RouterModule] 
})
export class AppRoutingModule { } export const 
RoutingComponent = [HomeComponent,ContactusComponent];

घटकों की श्रेणी अर्थात, RoutingComponent को app.module.ts में आयात किया जाता है -

import { BrowserModule } from '@angular/platform-browser'; 
import { NgModule } from '@angular/core';
import { AppRoutingModule , RoutingComponent} from './app-routing.module'; 
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, 
      RoutingComponent 
   ], 
   imports: [ 
      BrowserModule, 
      AppRoutingModule 
   ], 
   providers: [],
   bootstrap: [AppComponent] 
})
export class AppModule { }

तो अब हम मार्गों को परिभाषित करने के साथ किया जाता है। हमें उपयोगकर्ता के लिए समान प्रदर्शित करने की आवश्यकता है, इसलिए हम app.component.html में दो बटन, होम और हमसे संपर्क करें और संबंधित बटनों पर क्लिक करने पर, यह <रूटर-आउटलेट> निर्देश के अंदर घटक दृश्य प्रदर्शित करेगा जिसे हम add.component.html में जोड़ा है।

App.component.html के अंदर बटन बनाएं और बनाए गए मार्गों को रास्ता दें।

app.component.html

<h1>Angular 7 Routing Demo</h1> 
<nav> 
   <a routerLink = "/home">Home</a> 
   <a routerLink = "/contactus">Contact Us </a> 
</nav> 
<router-outlet></router-outlet>

.Html में, हमने एंकर लिंक, होम और हमसे संपर्क किया है और राउटरलिंक का इस्तेमाल किया है जो हमने ऐप-राउटिंग.module.ts में बनाए गए मार्गों को रास्ता देने के लिए किया है।

आइए अब हम ब्राउजर में इसका परीक्षण करते हैं -

यह हम ब्राउज़र में कैसे प्राप्त करते हैं। लिंक को अच्छा दिखाने के लिए कुछ स्टाइलिंग जोड़ें।

हमने app.component.css में निम्नलिखित सीएसएस जोड़ा है -

a:link, a:visited { 
   background-color: #848686; 
   color: white; 
   padding: 10px 25px; 
   text-align: center; 
   text-decoration: none; 
   display: inline-block; 
} 
a:hover, a:active {
   background-color: #BD9696;
}

यह ब्राउज़र में लिंक का प्रदर्शन है -

घर का घटक विवरण देखने के लिए होम लिंक पर क्लिक करें -

नीचे दिए गए अनुसार इसके घटक विवरण देखने के लिए, हमसे संपर्क करें पर क्लिक करें -

जैसे ही आप लिंक पर क्लिक करते हैं, आपको पता बार बदलते हुए पेज यूआरएल भी दिखाई देगा। यह पृष्ठ के अंत में पथ विवरण देता है जैसा कि ऊपर दिखाए गए स्क्रीनशॉट में देखा गया है।