Ng2 路由

Angular2中包含了一个路由框架,我们只需要定义一个个的路径和它对应的组件,然后在页面跳转时也是用Angular2的方式就能很方便的实现路由控制。

Angular2的路由包含下面4个部分:

  • 路由定义
  • 路由器
  • 导航
  • 参数

路由定义

路由定义,通俗来讲就是定义一个URL路径,打开的是哪个页面,由哪个组件来控制数据交互和用户交互,页面就是组件定义中定义的这个组件对应的模板页面。

路由器

路由器也就是分发器。当点击一个链接时,就是由他来确定要打开哪一个组件?怎么封装?怎么传递参数。

导航

就是指从一个页面打开另一个页面。有两种方式:

  • 通过页面上的一个链接link
  • 在JS中使用代码导航

参数

当我们在页面之间跳转时,通常都需要传递参数。除了常见的URL参数传递之外,在REST风格的路径设计中,经常使用某一个id作为url的一部分。

最简单的路由配置

S1:设置index.html页面的基址

打开index.html,确保它的<head>区顶部有一个<base href="...">元素(或动态生成该元素的脚本)。

S2:告诉路由器当用户点击链接时,应该显示哪个视图?

  • app.module.ts中导入RouterModule类,并在import数组中添加路径导航如下:

     RouterModule.forRoot([
          {
            path: 'heroes',
            component: HeroesComponent
          }
        ])
  • 路由出口

我们必须告诉路由器它位置,所以我们把<router-outlet>标签添加到模板的底部。 RouterOutlet是由RouterModule提供的指令之一。 当我们在应用中导航时,路由器就把激活的组件显示在<router-outlet>里面。

  • 路由器链接

导航的标准化配置

S1:在src下新建导航模块

app-routing.module.ts

S2:在文件中导入需要加入路由的组件和路由功能依赖的组件

    
    import { NgModule } from '@angular/core';
    import { HeroDetailComponent } from './hero-detail/hero-detail.component';
    import { DashboardComponent } from './dashboard/dashboard.component';
    import { HeroesComponent } from './heroes/heroes.component';
    
    // 添加路由功能支持
    import { RouterModule, Routes } from '@angular/router';
    // 添加path依赖
    const routes: Routes = [
        {
            path: 'heroes',
            component: HeroesComponent
        },
        {
            path: 'dashboard',
            component: DashboardComponent
        },
        {
            path: '',
            redirectTo: '/dashboard',
            pathMatch: 'full'
        },
        {
            path: 'herodetail/:id',  //带参数或者令牌的路由path
            component: HeroDetailComponent
        }
    ];
    
    @NgModule({
        imports: [RouterModule.forRoot(routes)],
        exports: [RouterModule]
    })
    export class AppRoutingModule { }

S3: 在app.module.ts中添加支持


    // 1. 导入路由模块
    import { AppRoutingModule } from './app-routing.module';
    ...
    //在import数组中添加模块 
    AppRoutingModule      //导入路由模块

S4-1:在html中引入方式


    <nav>
    <a routerLink='/dashboard' routerLinkActive="active">仪表盘</a>
    <a routerLink='/heroes' routerLinkActive="active">英雄列表</a>
    </nav>
    <router-outlet></router-outlet>

S4-2:在ts中使用的方法

1. 导入Router路由器组件

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

2. 在constructor中注入路由器实例
    
    constructor(
        private heroServce: HeroService,
        private router: Router) { }
3. 在函数中添加使用,执行函数后会导航到指定的组件页面

     gotoDetail(): void {
        this.router.navigate(['/herodetail', this.selectedHero.id]);
      }
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,185评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,445评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,684评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,564评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,681评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,874评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,025评论 3 408
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,761评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,217评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,545评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,694评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,351评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,988评论 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,778评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,007评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,427评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,580评论 2 349

推荐阅读更多精彩内容

  • 路由要解决的核心问题是通过建立URL和页面的对应关系,使得不同的页面可以用不同的URL表示。在angular中,页...
    oWSQo阅读 1,288评论 0 1
  • 版本:4.0.0+2 有一些英雄指南应用的新需求: 添加一个仪表盘 视图。 添加在英雄 视图和 仪表盘 视图之间导...
    soojade阅读 1,284评论 0 0
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 171,807评论 25 707
  • Spring Cloud为开发人员提供了快速构建分布式系统中一些常见模式的工具(例如配置管理,服务发现,断路器,智...
    卡卡罗2017阅读 134,633评论 18 139
  • 1,从本篇文章/音频/视频中我学到的最重要的概念 只有你对一门语言感兴趣,你才有可能学好他并且爱上他。 2,我在本...
    17数428宋琳阅读 173评论 2 0