我们用Angular cli创建带有路由的新项目

ng new router --routing

Angular Routes API文档

Angular的文档中有详细的解释:

1)https://angular.cn/docs/ts/latest/api/router/index/Routes-type-alias.html
2)https://angular.cn/docs/ts/latest/guide/router.html#

文档学习:

1)Wild Cards(通配符)

{path: '**', component: Code404Component}, 

>注意:配置路由,一定要记得引入文件

import {Code404Component} from "./code404/code404.component"

> 通配符路由的path是两个星号('**'),它会匹配任何URL。 当路由器匹配不上以前定义的那些路由时,它就会选择<这个>路由。 通配符路由可以导航到自定义的“404 Not Found”组件,也可以[重定向](https://angular.cn/docs/ts/latest/guide/router.html#redirect)到一个现有路由。

2)关于参数的快照(snapshot)和参数的订阅(subscribe)

export class ProductComponent implements OnInit {

private productId : number ;
//给ProductComponent设置一个属性(属性名是productId,属性类型是number)

constructor(private routerInfo : ActivatedRoute) { }
//ActivatedRoute当前路由激活的对象,保存着当前路由的信息,比如路由地址和路由参数

ngOnInit() {
this.productId = this.routerInfo.snapshot.queryParams["id"]; //参数快照
this.routerInfo.params.subscribe((params:Params) => this.productId = params ["id"]); //参数订阅
}
}

参数快照和参数订阅的区别:

![https://angular.cn/docs/ts/latest/guide/router.html#](http://upload-images.jianshu.io/upload_images/5983836-aa1cd314e9185f0d.gif?imageMogr2/auto-orient/strip)
>比如API中的这个图片,
参数快照:点了crisis后再点heroes,然后再点crisis是回不去的。
参数订阅:可以一直切换下去

3)在路由时传递数据(3种方法)
a.在查询参数中传递数据:

/product?id = 1&name = 2 => ActivatedRoute.queryParams[id]

b.在路由的路径中传递数据:

{path:/product/:id} => /product/1 => ActivatedRoute.params[id]

c.在路由配置中传递数据

{path:/product,component;ProductComponent,data:[{isProd:true}] }
=> ActivateRoute.data[0][isProd]

4)路由重定向

添加一个redirect路由来把最初的相对路径('')转换成期望的默认路径(/home)。 浏览器地址栏会显示.../home,就像你直接导航到那里一样。

const routes:Routes = [
{path : '' , redirectTo:'/home' , pathMath : 'full'},
{path : 'home' , component: HomeComponent},
]
//把当前的路由重定向到home路由上

重定向路由需要一个pathMatch属性,来告诉路由器如何使用URL去匹配路由的路径,否则路由就会报错,因此要把pathMacth设置为'full'

Angular Route导航的更多相关文章

  1. Angular+Bootstrap3导航菜单

    Angular+Bootstrap3导航菜单 AngularJS体验式编程系列文章,将介绍如何用angularjs构建一个强大的web前端系统.angularjs是由Google团队开发的一款非常优秀 ...

  2. 使用Angular Router导航基础

    名称 简介 Routes 路由配置,保存着那个URL对应着哪个组件,以及在哪个RouterOulet中展示组件. RouterOutlet 在HTML中标记路由内容呈现位置的占位符指令. Router ...

  3. angular route 与 django urls 冲突怎么解决?

    app.js var app = angular.module('app', [ 'ngResource', 'ngRoute', // 'ui.bootstrap', // 'ngResource' ...

  4. angular 实现导航ng-click切换

    angular写的导航.自学angular已有一段时间. <!doctype html><html lang="en"><head> <m ...

  5. angular -- $route API翻译

    $route -$routeProvider服务 -依赖ngRoute模块 $route能够在路径发生改变的时候,渲染不同的视图,调用不同的控制器.它监测了$location.url(),然后根据路径 ...

  6. 6、Angular Route 路由

    1.没有嵌套路由 类似 ui-route 上述的html用红字标记的是必须导入的.这是因为:路由并不在ng2中,需要我们额外引入,另外我们需要设置base href,这是个什么东西呢?相当于我们后续所 ...

  7. Angular route传参

    从 router-link-page1 跳转 router-link-page2 和 router-link-page3 通过自定义路由 设置router-link-page2的路由后有3个参数,pa ...

  8. [Angular] N things you might don't know about Angular Route

    Prevent Partail Page display: By using Resolver: @Injectable() export class MovieResolver implements ...

  9. 基于angular的route实现单页面cnodejs

    Angular ui-router 前言 之前不太理解前端怎么实现路由功能,以前知道有一种方式使用html5的pushState可以操作url才实现路由的功能,在实践项目中也用过一次,后来这种操作叫成 ...

随机推荐

  1. 将1、2、3、……、n这n个连续自然数分成g组,使每组的和相等。g组中个数最多的一组有几个?

    <style type="text/css"> #content { width: 600px; margin: 150px auto 0 auto; } dl dd ...

  2. 图解CSS选择器之nth家族

    1 nth-last-of-type  顾名思义从最后开始的元素开始选取可接受 数字 关键词 公式  比如4n+0就是每隔四个 odd even关键词表示奇偶数 .classify-item:nth- ...

  3. dubbo个人总结

    dubbo,分布式服务框架,RPC服务框架. 注册中心zk,redis......,使用大多为zk 注册流程 最后一图 服务提供者启动时向/dubbo/com.foo.BarService/provi ...

  4. Xamarin GitHub 下载的源码运行不了

     初学Xamarin ,各种折腾,大概这公司破电脑配置差,老是很多问题. GitHub 真是个好东西,可以参考别人做的,不过下载来运行不了就各种折腾了,为此我重装电脑两次了,反正win10安装就十几分 ...

  5. Keepalived高可用集群实践

    (1)实践的硬件环境准备 准备4台物理服务器或者4台VM虚拟机,其中两台用来做Keepalived服务器,两台做web测试站点 HOSTNAME I  P 解    释 lb01 10.0.0.7 K ...

  6. 【卸载】oracle卸载

    Oracle卸载比较麻烦,不能简单卸载就完成了,有时没有卸载完整,下次安装不能很好的安装: 当然Oracle卸载也没有那么难,只是步骤比较多.Oracle10g还是Oracle11g卸载步骤都是一样的 ...

  7. SourceTree 无法查看组织仓库

    error log: Pushing to remote: Repository not found. 在使用SourceTree进行版本控制,代替git命令行,而且作为免费 跨平台 功能完备的git ...

  8. ES6入门

    整理了ES6常用的一些语法,跟大家分享(promise.generator什么的还没有梳理清楚,后续再更新...) 1⃣️ 变量声明-let 与 const (首先关于测试结果:这里有个小问题,如果用 ...

  9. tomcat的环境搭建

    tomcat搭建过程还是比较简单的,只需要安装好jdk,然后配置好环境变量,最后把tomcat安装上开启就可以了. 首先下载jdk,然后把下载下来的jdk放到/usr/local下,然后用rpm -i ...

  10. 随机Prim法创建随机迷宫(C#实现)

    因为这两天想参加一个比赛,所以就在上网找素材,刚好看到了迷宫生成,就决定拿这个开刀了. 参考的原文地址为(来源页面) 源地址中是使用AS实现的,没学过AS,所以直接不会运行,于是就自己根据原文的概念进 ...