Angular7-ルーティング

ルーティングとは、基本的にページ間を移動することを意味します。新しいページに移動するためのリンクがあるサイトをたくさん見てきました。これは、ルーティングを使用して実現できます。ここで参照しているページは、コンポーネントの形式になります。コンポーネントの作成方法についてはすでに説明しました。ここで、コンポーネントを作成し、それでルーティングを使用する方法を見てみましょう。

プロジェクトのセットアップ中に、ルーティングモジュールがすでに含まれており、以下に示すように、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 上記のように追加され、imports配列に含まれます。

のファイルの詳細 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 { }

ここで、このファイルは、プロジェクトのセットアップ中にルーティングが追加されたときにデフォルトで生成されることに注意する必要があります。追加しない場合は、上記のファイルを手動で追加する必要があります。

したがって、上記のファイルでは、@ angular / routerからRoutesとRouterModuleをインポートしています。

constがあります routesルートタイプが定義されています。これは、プロジェクトで必要なすべてのルートを保持する配列です。

constルートは、@ NgModuleに示されているようにRouterModuleに与えられます。ルーティングの詳細をユーザーに表示するには、ビューを表示する場所に<router-outlet>ディレクティブを追加する必要があります。

以下に示すように、同じことが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とapp-routing.module.tsにインポートされていることに注意する必要があります。それらを1つの場所、つまりapp-routing.module.tsにインポートしましょう。

したがって、ルーティングに使用するコンポーネントの配列を作成し、その配列をapp-routing.module.tsにエクスポートしてから、app.module.tsに再度インポートします。したがって、app-routing.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にHomeとContact Usの2つのボタンを追加し、それぞれのボタンをクリックすると、<router-outlet>ディレクティブ内にコンポーネントビューが表示されます。 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では、アンカーリンク、[ホーム]と[お問い合わせ]を追加し、routerLinkを使用して、app-routing.module.tsで作成したルートへのパスを指定しました。

ブラウザで同じことをテストしてみましょう-

これがブラウザでの取得方法です。リンクの見栄えを良くするために、いくつかのスタイルを追加しましょう。

app.component.cssに次の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;
}

これはブラウザでのリンクの表示です-

以下に示すように、ホームリンクをクリックして、ホームのコンポーネントの詳細を表示します-

お問い合わせをクリックして、以下に示すコンポーネントの詳細を確認してください-

リンクをクリックすると、アドレスバーのページのURLも変化します。上記のスクリーンショットに示すように、ページの最後にパスの詳細が追加されます。