angular-cn/packages/router/test
Victor Berchet a755b715ed feat(router): introduce `ParamMap` to access parameters
The Router use the type `Params` for all of:
- position parameters,
- matrix parameters,
- query parameters.

`Params` is defined as follow `type Params = {[key: string]: any}`

Because parameters can either have single or multiple values, the type should
actually be `type Params = {[key: string]: string | string[]}`.

The client code often assumes that parameters have single values, as in the
following exemple:

```
class MyComponent {
sessionId: Observable<string>;

constructor(private route: ActivatedRoute) {}

ngOnInit() {
    this.sessionId = this.route
      .queryParams
      .map(params => params['session_id'] || 'None');
}
}

```

The problem here is that `params['session_id']` could be `string` or `string[]`
but the error is not caught at build time because of the `any` type.

Fixing the type as describe above would break the build because `sessionId`
would becomes an `Observable<string | string[]>`.

However the client code knows if it expects a single or multiple values. By
using the new `ParamMap` interface the user code can decide when it needs a
single value (calling `ParamMap.get(): string`) or multiple values (calling
`ParamMap.getAll(): string[]`).

The above exemple should be rewritten as:

```
class MyComponent {
sessionId: Observable<string>;

constructor(private route: ActivatedRoute) {}

ngOnInit() {
    this.sessionId = this.route
      .queryParamMap
      .map(paramMap => paramMap.get('session_id') || 'None');
}
}

```

Added APIs:
- `interface ParamMap`,
- `ActivatedRoute.paramMap: ParamMap`,
- `ActivatedRoute.queryParamMap: ParamMap`,
- `ActivatedRouteSnapshot.paramMap: ParamMap`,
- `ActivatedRouteSnapshot.queryParamMap: ParamMap`,
- `UrlSegment.parameterMap: ParamMap`
2017-03-20 09:19:32 -07:00
..
utils refactor: move angular source to /packages rather than modules/@angular 2017-03-08 16:29:27 -08:00
apply_redirects.spec.ts fix: element injector vs module injector (#15044) 2017-03-14 16:26:17 -07:00
bootstrap.spec.ts refactor: update paths from modules/@angular to packages 2017-03-08 16:29:28 -08:00
config.spec.ts refactor: move angular source to /packages rather than modules/@angular 2017-03-08 16:29:27 -08:00
create_router_state.spec.ts feat(router): introduce `ParamMap` to access parameters 2017-03-20 09:19:32 -07:00
create_url_tree.spec.ts feat(router): introduce `ParamMap` to access parameters 2017-03-20 09:19:32 -07:00
integration.spec.ts feat(router): introduce `ParamMap` to access parameters 2017-03-20 09:19:32 -07:00
recognize.spec.ts feat(router): introduce `ParamMap` to access parameters 2017-03-20 09:19:32 -07:00
router.spec.ts build: fix file paths after moving modules/@angular/* to packages/* 2017-03-08 16:29:28 -08:00
router_preloader.spec.ts refactor: move angular source to /packages rather than modules/@angular 2017-03-08 16:29:27 -08:00
router_state.spec.ts refactor: move angular source to /packages rather than modules/@angular 2017-03-08 16:29:27 -08:00
shared.spec.ts feat(router): introduce `ParamMap` to access parameters 2017-03-20 09:19:32 -07:00
spy_ng_module_factory_loader.spec.ts build: fix file paths after moving modules/@angular/* to packages/* 2017-03-08 16:29:28 -08:00
url_serializer.spec.ts feat(router): introduce `ParamMap` to access parameters 2017-03-20 09:19:32 -07:00
url_tree.spec.ts refactor: move angular source to /packages rather than modules/@angular 2017-03-08 16:29:27 -08:00