меню

Если есть динамическая ссылка, например:

  
<a [routerLink]="['/users', 10, 'Anna']">Load Anna (10)
 

И в шаблоне в ngOnInit() формируется объект по параметрам url:

 
this.user = {
    id: this.route.snapshot.params['id'],
    name: this.route.snapshot.params['name'],
}
  

Для обновления шаблона при переходе по такой ссылке необходимо подписаться на событие:

 
import { ActivatedRoute, Params } from '@angular/router';
//...
  ngOnInit() {
    this.user = {
      id: this.route.snapshot.params['id'],
      name: this.route.snapshot.params['name'],
    }
    this.route.params.subscribe(
      (params: Params) => {
      this.user.id = params['id'];
      this.user.name = params['name'];
      }
    );
  }
  

Когда вы подписываетесь на наблюдение в компоненте, практически всегда нужно отписываться, когда компонент уничтожается. ActivatedRoute является одним из немногих исключений, так как он отписывается автоматически. Тем не менее, отписываться является хорошей практикой, которая никогда не будет лишней.

 
//...
import { Subscription } from 'rxjs/Subscription';
//...
paramsSubscription: Subscription;
//...
ngOnInit() {
  //...
  this.paramsSubscription = this.route.params.subscribe(
    //...
  );
}

ngOnDestroy() {
  this.paramsSubscription.unsubscribe;
}  
  
Помощь сайту
ЮMoney:
4100 1180 7209 833
Карта Сбербанк:
2202 2080 6183 7127

Возможно, вам будет интересно

Binding свойств директив

Привязка входных и вторичных свойств директивы атрибута в Angular

Связывание свойств и событий

Создание кастомных событий и их обработчиков. Импорт свойств родительского компонента.

Формы. Шаблонный подход.

Работа с формами. Шаблонный подход (Template-driven)

Route. Контроль навигации с помощью сервиса

Деактивации роута в Angular5 и контроль навигации