helpservice .
static $inject = ['$scope', '$mdSidenav', 'helpService'];
constructor(private $scope: any,private $mdSidenav: any, private helpService:any) {
}
Typescript , this.helpService, TS this.helpService.loadAll " loadAll undefined" .
Arrow this @
this.helpService.loadAll()
.then((help) => { //<-- here
this.$scope.helpInfo = [].concat(help);
this.$scope.selected = this.$scope.helpInfo[0];
});
, this .
helpservice .
export interface IHelpService{
loadAll():ng.IPromise<Array<HelpInfo>>;
}
export interface HelpInfo{
name:string;
content:string;
}
class HelpService implements IHelpService{
private _helpInfo:Array<HelpInfo> = [{
name: 'Introduction',
content: '1 '
}, {
name: 'Glossary',
content: '2'
}, {
name: 'Log In',
content: '3'
}, {
name: 'Home Page',
content: '4'
}];
static $inject = ['$q'];
constructor(private $q:ng.IQService){
}
loadAll(){
return this.$q.when(this._helpInfo);
}
}
angular.module('HelpApp').service('helpService', HelpService);
constructor(private $scope: any,private $mdSidenav: any, private helpService:IHelpService) {
Typescript defn . , , - (, ).
export class SidenavController {
helpInfo:Array<HelpInfo>;
selected:HelpInfo;
static $inject = ['$mdSidenav', 'helpService'];
constructor(private $mdSidenav: any, private helpService:IHelpService) {}
toggleSidenav(name: string) {
this.$mdSidenav(name).toggle();
}
loadHelpInfo() {
this.helpService.loadAll()
.then((help) => {
this.helpInfo = [].concat(help);
this.selected = this.helpInfo[0];
})
}
selectHelpInfo(help) {
this.selected = angular.isNumber(help) ? this.helpInfo[help] : help;
this.toggleSidenav('left');
}
}
:
<body layout="column" ng-controller="AppCtrl as vm">
vm ( , vm). ( ): -
<md-item ng-repeat="it in vm.helpInfo">
<--- some code -->
<md-button ng-click="vm.selectHelpInfo(it)"
ng-class="{'selected' : it === vm.selected }">