Angular 數(shù)據(jù)請求的實(shí)現(xiàn)方法
使用 Angular 請求數(shù)據(jù)的時(shí)候,需要引入 HttpModule 模塊,如果使用的 jsonp 模式的話,則需要另外引入 JsonpModule 模塊
import { HttpModule, JsonpModule } from '@angular/http'
然后在當(dāng)前模塊中的 imports 內(nèi)進(jìn)行注冊
imports: [ HttpModule, JsonpModule ],
注冊以后就可以在組件文件當(dāng)中引入相對應(yīng)的方法來進(jìn)行數(shù)據(jù)請求了
import { Http, Jsonp } from '@angular/http'
然后在當(dāng)前組件的構(gòu)造函數(shù)當(dāng)中進(jìn)行注入以后就可以使用了
constructor(private http: Http, private jsonp: Jsonp) { }
使用如下,一個(gè)簡單的 get 請求
// 進(jìn)行注入,拿到相對應(yīng)的方法
constructor(private http: Http, private jsonp: Jsonp) { }
public list: any = []
// 請求數(shù)據(jù)
getData() {
let url = 'http://www.phonegap100.com/appapi.php?a=getPortalList&catid=20&page=1'
let _this = this
this.http.get(url).subscribe((data) => {
_this.list = JSON.parse(data['_body'])['result']
console.log(_this.list)
})
}
前臺(tái)進(jìn)行渲染即可
<button (click)="getData()">get 請求數(shù)據(jù)</button>
<ul>
<li *ngFor="let item of list">
{{item.title}}
</li>
</ul>
JSONP 請求數(shù)據(jù)
注意區(qū)分與 get 請求的區(qū)別,使用如下
// 請求數(shù)據(jù)
jsonpData() {
let url = 'http://www.phonegap100.com/appapi.php?a=getPortalList&catid=20&page=1&callback=JSONP_CALLBACK'
let _this = this
this.jsonp.get(url).subscribe((data) => {
_this.list = data['_body']['result']
console.log(_this.list)
})
}
// 渲染
<button (click)="jsonpData()">jsonp 請求數(shù)據(jù)</button>
<ul>
<li *ngFor="let item of list">
{{item.title}}
</li>
</ul>
不同點(diǎn)
請求的 url 參數(shù)結(jié)尾必須要添加指定的回調(diào)函數(shù)名稱 &callback=JSONP_CALLBACK
請求的方式變?yōu)?this.jsonp.get(url)
請求后得到的數(shù)據(jù)格式不統(tǒng)一,需要自行進(jìn)行調(diào)整
POST 請求
與 GET 的請求方式有些許不同,首先需要引入請求頭 { Headers }
import { Http, Jsonp, Headers } from '@angular/http'
然后來對請求頭進(jìn)行定義,需要先實(shí)例化 Headers
private headers = new Headers({'Content-Type': 'application/json'})
最后在提交數(shù)據(jù)的時(shí)候帶上 Headers 即可
postData() {
let url = 'http://localhost:8080/login'
let data = {
"username": "zhangsan",
"password": "123"
}
this.http.post(
url,
data,
{headers: this.headers}
).subscribe((data) => {
console.log(data)
})
}
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
AngularJs 利用百度地圖API 定位當(dāng)前位置 獲取地址信息
本文主要介紹了AngularJs 利用百度地圖API 定位當(dāng)前位置 獲取地址信息的方法步驟。具有一定的參考價(jià)值,下面跟著小編一起來看下吧2017-01-01
Angularjs中如何使用filterFilter函數(shù)過濾
這篇文章主要介紹了Angularjs中如何使用filterFilter函數(shù)過濾的相關(guān)資料,需要的朋友可以參考下2016-02-02
體驗(yàn)jQuery和AngularJS的不同點(diǎn)及AngularJS的迷人之處
AngualrJS是一個(gè)很貼心的web應(yīng)用框架,本篇通過jQuery和Angular兩種方式來實(shí)現(xiàn)同一個(gè)實(shí)例,從而體驗(yàn)兩者的不同點(diǎn)以及AngularJS的迷人之處2016-02-02
Angularjs自定義指令實(shí)現(xiàn)三級聯(lián)動(dòng) 選擇地理位置
這篇文章主要介紹了Angularjs自定義指令實(shí)現(xiàn)三級聯(lián)動(dòng),選擇地理位置,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-02-02

