亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

詳解Angular之路由基礎(chǔ)

 更新時(shí)間:2021年05月24日 09:57:56   作者:starof  
單頁應(yīng)用中,組件時(shí)構(gòu)建應(yīng)用的基礎(chǔ)元素,頁面展示什么內(nèi)容均是靠頁面有什么組件決定的,而展示什么組件又是由一組路由(帶有Url元素的特定集合,可用于導(dǎo)航視圖)決定的,希望本文可以幫助讀者了解路由的基礎(chǔ)概念和基礎(chǔ)使用、寫法。

一、路由相關(guān)對象

Router和RouterLink作用一樣,都是導(dǎo)航。Router是在Controller中用的,RouterLink是在模版中用到。

二、路由對象的位置

1、Routes對象

配置在模塊中。Routes由一組配置信息組成,每個(gè)配置信息至少包含兩個(gè)屬性,Path和Component。

2、RouterOutlet

在模版中

3、RouterLink

指令,在模版中生成鏈接改變URL

4、Router

在Controller中,調(diào)用Router對象的navigate方法,路由切換。

5、ActivatedRoute

路由時(shí)候通過URL傳遞數(shù)據(jù),數(shù)據(jù)會(huì)保存在ActivatedRoute對象中。

三、路由配置

使用ng new --routing參數(shù)時(shí)候會(huì)多生成出來一個(gè)app-routing.module.ts文件

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

const routes: Routes = [];

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

會(huì)自動(dòng)imports到app.module.ts中。

生成兩個(gè)組件home組件和component組件。

const routes: Routes = [
  {path: '', component : HomeComponent}, //路徑為空
  {path: 'product', component: ProductComponent}
];

注意:

1、path路徑配置不能以斜杠開頭,不能配置成path:'/product'。

因?yàn)锳ngular路由器會(huì)解析和生成url,不用/開頭是為了在多個(gè)視圖之間導(dǎo)航時(shí)能自由的使用相對路徑和絕對路徑。

2、在模版中寫路徑時(shí),必須用/開頭。

因?yàn)橛眯备芗?表示要導(dǎo)航到根路由(/)還是子路由(./)。

/就是導(dǎo)航到根路由,從配置根路由那一層找。

<a [routerLink]="['/']">主頁</a>

3、在<router-outlet>下面顯示組件內(nèi)容

4、routerLink參數(shù)是一個(gè)數(shù)組而不是字符串

因?yàn)樵诼酚蓵r(shí)候可以傳遞參數(shù)。

四、代碼中通過Router對象導(dǎo)航

模版上加一個(gè)按鈕

<input type="button" value="商品詳情" (click)="toProductDetails()">

controller中使用router.navigate導(dǎo)航。

navigate參數(shù)和routerLink參數(shù)配置一樣。

import { Component } from '@angular/core';
import { Router } from '@angular/router';

@Component({
  selector: 'app-root',
  templateUrl: './app.component.html',
  styleUrls: ['./app.component.css']
})
export class AppComponent {
  constructor(private router:Router){
  }
  toProductDetails(){
    this.router.navigate(['/product']);
  }
}

點(diǎn)按鈕和點(diǎn)鏈接效果一樣。

五、配置不存在的路徑

生成code404組件顯示頁面不存在。

路由匹配先匹配者優(yōu)先,所以**通配符路由要放最后。

const routes: Routes = [
  { path: '', component: HomeComponent }, //路徑為空
  { path: 'product', component: ProductComponent },
  { path: '**', component: Code404Component }
];

六、重定向路由

一個(gè)地址重定向到另一個(gè)指定組件

www.aaa.com => www.aaa.com/products

www.aaa.com/x => www.aaa.com/y 用戶可能已經(jīng)收藏了x地址。

用重定向路由

const routes: Routes = [
  { path: '', redirectTo : 'home', pathMatch:'full' }, //路徑為空
  { path: 'home', component: HomeComponent },
  { path: 'product', component: ProductComponent },
  { path: '**', component: Code404Component }
];

七、在路由時(shí)候傳遞數(shù)據(jù)

有3種方式

1、在查詢參數(shù)中傳遞數(shù)據(jù)

2、在路由路徑中傳遞數(shù)據(jù)

定義路由路徑時(shí)就要指定參數(shù)名字,在實(shí)際路徑中攜帶參數(shù)。

3、在路由配置中傳遞數(shù)據(jù)

以上就是詳解Angular之路由基礎(chǔ)的詳細(xì)內(nèi)容,更多關(guān)于Angular之路由基礎(chǔ)的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

最新評論