1. 程式人生 > >AngularJS中$http服務的簡單用法

AngularJS中$http服務的簡單用法

我們可以使用內建的$http服務直接同外部進行通訊。$http服務只是簡單的封裝了瀏覽器原生的XMLHttpRequest物件。

1、鏈式呼叫

$http服務是隻能接受一個引數的函式,這個引數是一個物件,包含了用來生成HTTP請求的
配置內容。這個函式返回一個promise物件,具有success和error兩個方法。
$http({
url:'data.json',
method:'GET'
}).success(function(data,header,config,status){
//響應成功

}).error(function(data,header,config,status){
//處理響應失敗
});

2、返回一個promise物件
var promise=$http({
method:'GET',
url:"data.json"
});

由於$http方法返回一個promise物件,我們可以在響應返回時用then方法來處理回撥。如果
使用then方法,會得到一個特殊的引數,它代表了相應物件的成功或失敗資訊,還可以接受兩個
可選的函式作為引數。或者可以使用success和error回撥代替。
promise.then(function(resp){
//resp是一個響應物件

},function(resp){
//帶有錯誤資訊的resp

});

或者這樣:
promise.success(function(data,status,config,headers){
//處理成功的響應
});

promise.error(function(data,status,hedaers,config){
//處理失敗後的響應
});

then()方法與其他兩種方法的主要區別是,它會接收到完整的響應物件,而success()和error()則會對響應對
象進行析構。

3、快捷的get請求

①$http.get('/api/users.json');

get()方法返回HttpPromise物件。

還可以傳送比如:delete/head/jsonp/post/put 函式內可接受引數具體參照148頁


②以再發送jsonp請求舉例說明: 為了傳送JSONP請求,其中url必須包含JSON_CALLBACK字樣。

jsonp(url,config) 其中config是可選的

var promise=$http.jsonp("/api/users.json?callback=JSON_CALLBACK");



4、也可以將$http當做函式來使用,這時需要傳入一個設定物件,用來說明如何構造XHR物件。

$http({
method:'GET',
url:'/api/users.json',
params:{
'username':'tan'
});
 
其中設定物件可以包含以下主要的鍵:
①method
可以是:GET/DELETE/HEAD/JSONP/POST/PUT

②url:絕對的或者相對的請求目標
③params(字串map或者物件)
這個鍵的值是一個字串map或物件,會被轉換成查詢字串追加在URL後面。如果值不是字串,會被JSON序列化。
比如這個:

//引數會轉為?name=ari的形式
$http({
params:{'name':'ari'}
});

④data(字串或者物件)
這個物件中包含了將會被當作訊息體傳送給伺服器的資料。通常在傳送POST請求時使用。

從AngularJS 1.3開始,它還可以在POST請求裡傳送二進位制資料。要傳送一個blob物件,你可以簡單地通過使用data引數來傳遞它。
例如:
var blob=new Blob(['Hello world'],{type:'text/plain'});
$http({
method:'POST',
url:'/',
data:blob
});

4、響應物件

AngularJS傳遞給then()方法的響應物件包含了四個屬性。
◇data
這個資料代表轉換過後的響應體(如果定義了轉換的話)
◇status
響應的HTTP狀態碼
◇headers
這個函式是頭資訊的getter函式,可以接受一個引數,用來獲取對應名字值

例如,用如下程式碼獲取X-Auth-ID的值:
$http({
method: 'GET',
url: '/api/users.json'
}).then (resp) {
// 讀取X-Auth-ID
resp.headers('X-Auth-ID');
});

◇config
這個物件是用來生成原始請求的完整設定物件。

◇statusText(字串)
這個字串是響應的HTTP狀態文字。

5、快取HTTP請求
預設情況下,$http服務不會對請求進行本地快取。在傳送單獨的請求時,我們可以通過向$http請求傳入一個布林值或者一個快取例項來啟用快取。
$http.get('/api/users.json',{ cache: true })
.success(function(data) {})
.error(function(data) {});

第一次傳送請求時,$http服務會向/api/users.json傳送一個GET請求。第二次傳送同一個GET請求時,$http服務會從快取中取回請求的結果,而不會真的傳送一個HTTP GET請求。
在這個例子裡,由於設定了啟用快取,AngularJS預設會使用$cacheFactory,這個服務是AngularJS在啟動時自動建立的。

如果想要對AngularJS使用的快取進行更多的自定義控制,可以向請求傳入一個自定義的快取例項代替true。