Ionic2系列之使用DeepLinker实现指定页面URL

  

关于“Ionic2系列之使用DeepLinker实现指定页面URL”的完整攻略,我们可以进行如下的讲解:

概述

在Ionic2应用中,使用DeepLinker可以轻松地实现URL指定页面跳转的效果。DeepLinker可以将页面和URL映射起来,这样就能够通过URL来精确地打开指定的页面了。

详细步骤

下面我们将会依次介绍使用DeepLinker实现指定页面URL的详细步骤。

配置URL匹配规则

要使用DeepLinker实现指定页面URL,首先需要在应用的根模块(通常是app.module.ts)中配置URL匹配规则,例如:

@NgModule({
  ...
  imports: [
    IonicModule.forRoot(MyApp, {
      // 配置URL匹配规则
      links: [
        {component: HomePage, name: 'home', segment: 'home'},
        {component: AboutPage, name: 'about', segment: 'about'},
        {component: ContactPage, name: 'contact', segment: 'contact'},
      ]
    })
  ],
  ...
})
export class AppModule {}

上面的代码配置了如下三个URL匹配规则:

  • /home 匹配 HomePage 组件
  • /about 匹配 AboutPage 组件
  • /contact 匹配 ContactPage 组件

配置路由链接

配置完URL匹配规则之后,就可以在页面中配置链接了。例如,在 HomePage 组件中配置 “去往 About 页面” 的链接:

<a [routerLink]="['/about']">去往 About 页面</a>

这里使用了 routerLink 指令来配置链接,传入的参数就是 URL 中的路径部分。在这个例子中,链接的路径是 /about,因此会触发匹配规则中 name 属性为 about 的那个规则。

获取URL参数

DeepLinker不仅支持简单的URL匹配,还支持从URL中获取参数。例如,在 AboutPage 组件中定义一个可以显示用户ID的标签:

<p>用户ID是:{{userId}}</p>

可以通过在 app.module.ts 中配置 AboutPage 的URL匹配规则时,使用冒号加参数名的形式来定义参数的匹配规则:

@NgModule({
  ...
  imports: [
    IonicModule.forRoot(MyApp, {
      // 配置URL匹配规则
      links: [
        ...
        {component: AboutPage, name: 'about', segment: 'about/:userId'},
        ...
      ]
    })
  ],
  ...
})
export class AppModule {}

上面的代码中,':userId' 表示URL路径中的参数名为 userId

AboutPage 组件中,可以通过 ActivatedRoute 服务获取参数值:

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

@Component({
  templateUrl: 'about.html'
})
export class AboutPage {
  userId: string;

  constructor(private route: ActivatedRoute) {
    this.userId = this.route.snapshot.paramMap.get('userId');
  }
}

上面的代码中,通过 route.snapshot.paramMap.get('userId') 获取了参数值,并赋值给了 userId 变量。

示例说明

下面我们来看两个示例,说明在实际应用中如何使用DeepLinker实现指定页面URL。

示例1:跳转到文章详情页

假设我们有一个文章列表页面,点击列表项可以跳转到对应的文章详情页。文章详情页的URL可能为 /article/:id,其中 id 为文章ID。

我们可以在文章列表页面中这样定义跳转链接:

<!-- 假设 articles 是文章列表数组 -->
<div *ngFor="let article of articles">
  <a [routerLink]="['/article', article.id]">{{article.title}}</a>
</div>

上面的代码中,使用了 article.id 作为参数值,这样点击链接时就会跳转到 /article/1/article/2 等不同地址。

在文章详情页的组件中,我们可以通过 ActivatedRoute 来获取参数值:

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

@Component({
  templateUrl: 'article.html'
})
export class ArticlePage {
  articleId: string;

  constructor(private route: ActivatedRoute) {
    this.articleId = this.route.snapshot.paramMap.get('id');
  }
}

示例2:区分不同类型的用户

假设我们有一个用户列表页面,用户有两种类型:1、普通用户;2、管理员用户。我们在用户列表页面中可以区分不同类型的用户,并跳转到对应的用户详情页。用户详情页的URL为 /user/:type/:id,其中 type 为用户类型,id 为用户ID。

我们可以在用户列表页面中这样定义跳转链接:

<!-- 假设 users 是用户列表数组 -->
<div *ngFor="let user of users">
  <!-- 假设普通用户的type为1,管理员用户的type为2 -->
  <a [routerLink]="['/user', user.type, user.id]">{{user.username}}</a>
</div>

上面的代码中,我们把 user.type 作为第一个参数值,这样点击链接时就会跳转到 /user/1/1/user/1/2 等不同地址。

在用户详情页的组件中,我们可以通过 ActivatedRoute 来获取两个参数值:

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

@Component({
  templateUrl: 'user.html'
})
export class UserPage {
  userId: string;
  userType: string;

  constructor(private route: ActivatedRoute) {
    this.userId = this.route.snapshot.paramMap.get('id');
    this.userType = this.route.snapshot.paramMap.get('type');
  }
}

结语

以上就是使用DeepLinker实现指定页面URL的完整攻略。当然,实际应用中可能还需要解决许多其他问题,例如参数类型转换、URL的动态生成、URL的可配置性等等。希望这篇攻略对读者有所帮助。

相关文章