У меня есть маршрут, называемый home, и у него есть три дочерних маршрута, документы, почта и корзина. В компоненте домашнего маршрута у него есть переменная, называемая «пользователь». Я знаю, что есть несколько способов передачи информации между родительскими и дочерними компонентами, выделенными here, но как я могу передать информацию между родительскими/дочерними маршрутами.angular2 - передать значение от родительского маршрута до детского маршрута
{ path: 'home', component: HomeComponent, children: [
{ path: 'documents', component: DocumentsComponent },
{ path: 'mail', component: MailComponent },
{ path: 'trash', component: TrashComponent },
]
},
служба
import { Injectable } from '@angular/core';
@Injectable()
export class HomeService {
// Mock user, for testing
myUser = {name:"John", loggedIn:true};
// Is Super Admin
isLogged():boolean {
if(this.myUser.role == true){
return true ;
}
return false ;
}
}
Компонент
constructor(public router: Router, public http: Http, private homeService: HomeService) {
}
isLogged(){
return this.homeService.isLogged();
}
Шаблон
<div class="side-nav fixed" >
<li style="list-style: none">
<img alt="avatar" class="circle valign profile-image" height="64" src=
"../images/avatar.jpg" width="64">
<div class="right profile-name">
<!-- Value not changing even with service -->
{{myUser.role}}
</div>
</li>
Не работает для меня – John
Не работает для вас, вы не способный реализовать это или у вас есть другой сценарий? Если в другом случае добавьте более подробную информацию. –
В моем шаблоне html у меня есть ngIf, чтобы проверить, вошел ли пользователь в систему. Тем не менее, он не читает метод службы, который проверяет. – John