$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(res){
        //請求響應成功需要執行的代碼塊
        //res是一個響應對象是從後臺獲取的數據
        },function(res){
        //請求失敗會執行的代碼塊
        //帶有錯誤信息的res});
或者
    promise.success(function(data,status,config,headers){
    //處理成功的響應
    });
    promise.error(function(data,status,hedaers,config){
    //處理失敗後的響應
    });
then()方法與其他兩種方法的主要區別是,它會接收到完整的響應對象。而success()和error()則會對響應對象進行析構。

3、快捷的get請求
1)http.get(/api/users.json);get()HttpPromisedelete/head/jsonp/post/put2jsonpJSONPurlJSONCALLBACKjsonp(url,config)configvarpromise= 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使AngularJS1.3POSTblob使datavarblob=newBlob([Helloworld],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。
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章