Angular4 开发实战:(7) 创建服务(Service)
ng g service book
自动生成的基础模板:
import { Injectable } from '@angular/core';
@Injectable()
export class BookService {
constructor() { }
}
建议每一个服务都加上@Injectable()
装饰器。
注意: 当 TypeScript 看到@Injectable()
装饰器时,就会记下本服务的元数据。 如果 Angular 需要往这个服务中注入其它依赖,就会使用这些元数据。
现在我们添加一个获取书籍列表的方法:
export class BookService {
getBooks() {}
}
我们使用Http来从服务器获取数据,但使用前需要注册入:
// app.module.ts
import { HttpModule } from '@angular/http';
@NgModule({
...
imports: [
...
HttpModule
],
providers: [],
bootstrap: [AppComponent]
})
我在这里模拟一个书籍书籍,创建一个book.json
:
{
"books": [
{
"name": "HTML"
},
{
"name": "Javascript"
},
{
"name": "Angular"
}
]
}
接下来修改一下book.service.ts
:
import { Injectable } from '@angular/core';
import {Http} from '@angular/http';
import 'rxjs/add/operator/toPromise';
@Injectable()
export class BookService {
constructor(private http: Http) { }
getBooks() {
const url = '/src/app/service/book.json';
return this.http.get(url)
.toPromise()
.then(res => res.json())
.catch(this.handleError);
}
private handleError(error: any): Promise<any> {
console.error('An error occurred', error); // for demo purposes only
return Promise.reject(error.message || error);
}
}
注:默认情况下,Angular 的Http服务返回一个 RxJS 的Observable对象。 我们可以通过toPromise()
方法将其转为便捷的承诺Promise。
使用toPromise()
方法时要引入:
import 'rxjs/add/operator/toPromise';
接下来我们要使用这个BookService
服务了:
// demo-service.service.ts
import { Component, OnInit } from '@angular/core';
import {BookService} from '../../service/book.service';
@Component({
...
providers: [BookService]
})
export class DemoServiceComponent implements OnInit {
books: any[];
constructor(private bookService: BookService) { }
ngOnInit() {
this.bookService.getBooks()
.then(res => {
this.books = res.books;
});
}
}
// demo-service.component.html
<li *ngFor="let book of books">{{book.name}}</li>
在上面的代码中,我们做了三步工作:
1. 将BookService
服务添加到@Component
组件的元数据底部添加providers
数组属性中。
2. 将BookService
注入到构造方法中,并定义了一个私有属性bookService
。
3. 在OnInit()
生命钩子函数中调用服务并获取书籍数据
注:
providers
数组告诉 Angular,当它创建新的DemoServiceComponent
组件时,也要创建一个BookService
的新实例。- 尽量不要在构造方法中获取服务数据,要在生命钩子函数中调用。
GET
)数据:
get() {
return this.http.get(url)
.toPromise()
.then(response => response.json() )
.catch(this.handleError);
}
private handleError(error: any): Promise<any> {
console.error('An error occurred', error); // for demo purposes only
return Promise.reject(error.message || error);
}
新建(POST
)数据:
private headers = new Headers({'Content-type': 'application/json'});
create() {
return this.http
.post(url, JSON.stringify(hero), {headers: this.headers})
.toPromise()
.then(response => response.json())
.catch(this.handleError);
}
更新(update
)数据:
private headers = new Headers({'Content-type': 'application/json'});
update() {
return this.http
.put(url, JSON.stringify(hero), {headers: this.headers})
.toPromise()
.then(response => response.json())
.catch(this.handleError);
}
删除(DELETE
)数据:
private headers = new Headers({'Content-type': 'application/json'});
delete() {
return this.http
.delete(url, {headers: this.headers})
.toPromise()
.then(() => null)
.catch(this.handleError);
}
如发现任何问题或有好的建议,欢迎在下方评论留言。