我正在尝试了解服务注入在 Angular 2 中的工作原理。我创建了一个应用程序和一个服务。我的服务如下:
import {Injectable} from 'angular2/core';
@Injectable()
export class UserService {
logged: boolean;
users: Array<any>;
constructor () {
this.logged = false;
this.users = [
{username: 'david', password: 'password'}
]
}
checkLogin (username, password) {
this.users.forEach((user) => {
if (user.username == username && user.password == password) {
this.logged = true;
return true;
} else {
this.logged = false;
return false;
}
})
}
logOut () {
this.logged = false;
}
}
我将它注入到引导程序中,以便我可以在整个应用程序中访问它,如下所示:
import {bootstrap} from 'angular2/platform/browser'
import {AppComponent} from './components/app.component'
import {ROUTER_PROVIDERS} from 'angular2/router';
import {UserService} from './services/user.service';
bootstrap(AppComponent, [ROUTER_PROVIDERS, UserService]);
然后我尝试在我的一个组件视图中访问它,但不能这样做。我试图像这样访问它:
import {Component} from 'angular2/core';
import {ROUTER_DIRECTIVES} from "angular2/router";
@Component({
selector: 'navbar',
template: '<li><a>{{UserService.logged}}</a></li>',
directives: [ROUTER_DIRECTIVES],
})
export class NavbarComponent {
}
它不允许我访问变量,这是为什么呢?