继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

路由之跳转与传参

为爱心太软
关注TA
已关注
手记 170
粉丝 1.4万
获赞 860

路由跳转

通常理解的页面跳转是,发生点击事件时,从一个页面跳转到另一个页面的过程。
但对于 Angular 这种单页面应用而言,页面跳转只是与路径进行匹配,若匹配成功则渲染相应的组件,并通过 html5 的 history.pushState 方法更新历史记录。

模板中的指令跳转

在模板文件中,通过 RouterLink 指令来设置路由跳转。

例子:

app-routing.module.ts

import { NgModule } from '@angular/core';
import { RouterModule, Routes } from '@angular/router';
import { LoginComponent } from './components/login/login.component';
import { WelcomeComponent } from './components/welcome/welcome.component';
import { PageNotFoundComponent } from './components//page-not-found/page-not-found.component';
import { AboutComponent } from './components//about/about.component';

const routes: Routes = [
  { 
    path: 'login', 
    component: LoginComponent
  },
  { 
    path: 'welcome', 
    component: WelcomeComponent
  },
  { 
    path: 'about', 
    component: AboutComponent
  },
  { 
    path: '', 
    redirectTo: '/login', 
    pathMatch: 'full'
  },
  { path: '**', 
    component: PageNotFoundComponent
  }
];

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

app.component.html

<section>
  <header style="text-align: center;">
    <h2>大连 —— 美丽的北方明珠</h2>
  </header>

  <p style="display: flex; justify-content: space-evenly;">
    <a [routerLink]="['/welcome']">欢迎页面</a>
    <a [routerLink]="['/about']">关于大连</a>
  </p>
  
  <hr>
  <router-outlet></router-outlet>

  <footer></footer>
</section>

图片描述

图片描述

RouterLink 指令不局限于 <a> 标签,它可以被应用在任何 html 标签上,比如常用的 <button>

例子:

// app.component.html
<p style="display: flex; justify-content: space-evenly;">
  <button [routerLink]="['/welcome']">欢迎页面</button>
  <button [routerLink]="['/about']">关于大连</button>
</p>

图片描述

当 RouterLink 被激活时,可以通过 routerLinkActive 指令指定 CSS 类。

例子:

// app.component.scss
.active{
  border: 1px solid red;
}

// app.component.html
<p style="display: flex; justify-content: space-evenly;">
  <button [routerLink]="['/welcome']" [routerLinkActive]="['active']">欢迎页面</button>
  <button [routerLink]="['/about']" [routerLinkActive]="['active']">关于大连</button>
</p>

图片描述

组件中的代码跳转

在组件中,通过 Router.navigate() 方法来完成跳转。

例子:

app.component.html

<p style="display: flex; justify-content: space-evenly;">
  <button (click)="toWelcome()">欢迎页面</button>
  <button (click)="toAbout()">关于大连</button>
</p>

app.component.ts

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

// 导入 Router 对象
import { Router } from '@angular/router';

@Component({
  selector: 'app-root',
  templateUrl: './app.component.html',
  styleUrls: ['./app.component.scss']
})
export class AppComponent {

  constructor(

    // 初始化 Router 对象
    private router: Router,
  ) { }

  // 跳转 welcome 页面
  toWelcome(){
    this.router.navigate(['/welcome']);
  }

  // 跳转 about 页面
  toAbout(){
    this.router.navigate(['/about']);
  }

}

图片描述

图片描述

路由传参

Angular 路由具有传递参数的功能,可以通过 URL 向目标组件传递数据。

路径参数

// 基本形式
http://localhost:4200/welcome/李雷

路径参数,顾名思义,在配置路由的 path 属性时,可以在路径一段的前面添加冒号,表明这是一个参数。

// 在 path 下配置路由参数 name
{ 
  path: 'welcome/:name', 
  component: WelcomeComponent
}

接下来,不管是手动输入 URL,还是通过 RouterLink,或者 Router.navigate() 完成跳转,都需要给参数 name 赋值。

[routerLink]="['/welcome','李雷']"
this.router.navigate(['/welcome','李雷']);

图片描述

获取参数

为了使用路径参数,我们需要在目标组件中导入 ActivatedRoute 对象。
该 ActivatedRoute 对象包含了一个 params 参数订阅,可以从 URL 中解析出路径参数。

例子:

welcome.component.ts

import { Component, OnInit } from '@angular/core';

// 导入 ActivatedRoute
import { ActivatedRoute } from '@angular/router';

@Component({
  selector: 'app-welcome',
  templateUrl: './welcome.component.html',
  styleUrls: ['./welcome.component.scss']
})
export class WelcomeComponent implements OnInit {
  name!:string;

  constructor(

    // 初始化 ActivatedRoute
    private activedRoute: ActivatedRoute,
  ) { }

  ngOnInit() {

    // 使用参数订阅
    this.activedRoute.params.subscribe((params:any)=>{
      this.name = params['name'];
    });
  }

}

图片描述

查询参数

// 基本形式
http://localhost:4200/welcome?name=李雷&local=武汉

查询参数无需在 path 属性中进行配置,而且可以拥有任意多个参数。
同样通过 RouterLink 或者 Router.navigate() 来赋值。

[routerLink]="['/welcome']" [queryParams]="{name:'李雷', local:'武汉'}"

this.router.navigate(
    ['/welcome'],
    {
      queryParams:{
        name:'李雷',
        local:'武汉'
      }
    }
  );

获取参数

通过 ActivatedRoute 对象的 queryParams 参数订阅,获取到查询参数。

this.activedRoute.queryParams.subscribe((queryParams:any)=>{
  this.name = queryParams['name'];
  this.local = queryParams['local'];
});

图片描述


end

打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP