资讯专栏INFORMATION COLUMN

angular4实战(2) router

wanglu1209 / 3105人阅读

摘要:在上一章节,通过新建项目之后,会自动引入路由模块,接下来需要做的事情就是对路由模块进行配置。为了方便维护,多带带把路由模块的配置拿出来,再去输出到中。路由守卫业务需求是在没有登录的情况下,是不允许跳入到下一个页面的。

router

单页面应用通过路由来去渲染不同的视图,为用户在同一个页面看到不同的场景,提供基础服务。

在上一章节,通过新建项目之后,ngModule会自动引入路由模块,接下来需要做的事情就是对路由模块进行配置。为了方便维护,多带带把路由模块的配置拿出来,再去输出到ngModule中。

import {NgModule} from "@angular/core";
import {Routes, RouterModule} from "@angular/router";
import {LoginComponent} from "./core/login/login.component";
import {NotFoundComponent} from "./core/not-found/not-found.component";
import {Auth} from "./core/login/login.Auth";

const routes: Routes = [
  {path: "login", component: LoginComponent},
  {path: "stones", loadChildren: "./stones/stones.module#StonesModule", canActivate: [Auth]},
  {path: "", redirectTo: "/login", pathMatch: "full"},
  {path: "**", component: NotFoundComponent}
];

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

在app组件下,暂时只引了三个组件,一个是项目启动的默认登录页面,一个是404页面,另一个是stones组件,这个组件又会作为一个父级的路由容器来去管理他下面的页面。

这样做的理由是,为了在页面多了之后方便管理,层级上面一定要分明,不能扁平化,所有的东西都一股脑的挂在app下面。通过引入stones路由,再让stones路由去管理其他的子路由是一个不错的选择。
项目结构如下:

(ps:项目本身一直在写,之后可能有所改变,但思路不变,不直接通过app根节点去管理)

在路由的具体的配置方面:

{path: "", redirectTo: "/login", pathMatch: "full"}

redirectTo表示在页面路由为空时(一般是刚进入项目),会重定向到login页面。

{path: "**", component: NotFoundComponent}

路由是根据path自上而下匹配的,如果说浏览器中的地址上的路由变成一个不存在的值时,那么会一直向下匹配,直到匹配到**,这个可以匹配任意路由的配置,这也是做404页面的原理,因此一定要把**这个配置写在最后一行。

  {path: "stones", loadChildren: "./stones/stones.module#StonesModule", canActivate: [Auth]},
路由守卫

业务需求是在没有登录的情况下,是不允许跳入到下一个页面的。这时路由守卫就派上了用场。

用CanActivate来处理导航到某路由的情况。
用CanDeactivate来处理从当前路由离开的情况.

最常用的是这两个属性,类似于react的enter和leave,只是描述不同,都是用来对进入和离开路由做限制的,它们接受一个布尔值,来是否同意用户在路由上做跳转。

以一个登录举例,这里引入的Auth,是一个判断是否登录的方法。
login.Auth.ts:

import {Injectable} from "@angular/core";
import {Router, CanActivate} from "@angular/router";
import {NotyService} from "../../service/noty/noty.service";

@Injectable()
export class Auth implements CanActivate {
  constructor(private noty: NotyService, private route: Router) {
  }

  canActivate() {
    return sessionStorage.getItem("user")
      ? true
      : (this.noty.alert({
        text: "????请登录~~????"
      }), this.route.navigate(["/login"]), false);
  }
}

直接在浏览器中更改stones路由,就会触发这个函数,以此来检测是否登录。

本章路由到此为止,下一章节主要讲UI框架的引入及在ts中引用js插件。

项目地址:https://github.com/jiwenjiang...

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/88656.html

相关文章

  • Angular4 实战开发

    摘要:实战系列目前处于章节不定,内容不定阶段,这一系列文章不会长篇大论的讲解概念,而是以用为主,结合通俗易懂的实例来让大家理解常用的知识点。原文链接实战开发 《Angular 实战系列》目前处于章节不定,内容不定阶段,这一系列文章不会长篇大论的讲解概念,而是以用为主,结合通俗易懂的实例来让大家理解常用的知识点。 章节 Angular CLI 创建组件(Component) 使用CSS美化组...

    Hegel_Gu 评论0 收藏0
  • Angular4 实战开发

    摘要:实战系列目前处于章节不定,内容不定阶段,这一系列文章不会长篇大论的讲解概念,而是以用为主,结合通俗易懂的实例来让大家理解常用的知识点。原文链接实战开发 《Angular 实战系列》目前处于章节不定,内容不定阶段,这一系列文章不会长篇大论的讲解概念,而是以用为主,结合通俗易懂的实例来让大家理解常用的知识点。 章节 Angular CLI 创建组件(Component) 使用CSS美化组...

    vboy1010 评论0 收藏0
  • angular4路由 知道这些就够用了

    摘要:路由使用命令创建根路由模块或自己建一个路由配置文件如将文件修改为以后在这里改动配置将路由配置导出为以供调用子模块中的路由使用而不是在根模块中引入路由为特性模块定义的路由在其模块中引入路由配置路径组件路径组件懒加载子模块子模块需要配置路由设置 angular 4 路由 使用cli命令创建根路由模块 ng g cl app.router 或自己建一个路由配置文件 如:app/app.rou...

    caikeal 评论0 收藏0
  • angular4学习记录 -- 路由

    摘要:通过设置路由参数,控制辅助路由的插座是否显示组件内容。具体设置路由守卫在设置路由守卫时需先做下面两步一在中添加二在中添加需要守卫的路由的或者,前两个是数组形式,是对象形式。在路由激活之前获取路由数据在文件中实现接口 Angular4 路由 路由时传递数据 1.在查询参数中传递数据 /product?id=1&name=2 => ActivateRoute.queryParams[id]...

    FullStackDeveloper 评论0 收藏0

发表评论

0条评论

最新活动
阅读需要支付1元查看
<