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