欧美成人午夜免费全部完,亚洲午夜福利精品久久,а√最新版在线天堂,另类亚洲综合区图片小说区,亚洲欧美日韩精品色xxx

扣丁學(xué)堂HTML5培訓(xùn)淺談AngularJS中$http服務(wù)用法

2018-05-17 11:09:36 1279瀏覽

我們可以使用內(nèi)置的$http服務(wù)直接同外部進行通信。$http服務(wù)只是簡單的封裝了瀏覽器原生的XMLHttpRequest對象。



1、鏈?zhǔn)秸{(diào)用

$http服務(wù)是只能接受一個參數(shù)的函數(shù),這個參數(shù)是一個對象,包含了用來生成HTTP請求的配置內(nèi)容。這個函數(shù)返回一個promise對象,具有success和error兩個方法。

$http({
url:'data.json',
method:'GET'
}).success(function(data,header,config,status){
//響應(yīng)成功
}).error(function(data,header,config,status){
//處理響應(yīng)失敗
});

2、返回一個promise對象

varpromise=$http({
method:'GET',
url:"data.json"
});

由于$http方法返回一個promise對象,我們可以在響應(yīng)返回時用then方法來處理回調(diào)。如果使用then方法,會得到一個特殊的參數(shù),它代表了相應(yīng)對象的成功或失敗信息,還可以接受兩個可選的函數(shù)作為參數(shù)?;蛘呖梢允褂胹uccess和error回調(diào)代替。

  promise.then(function(resp){
  //resp是一個響應(yīng)對象
  },function(resp){
  //帶有錯誤信息的resp
  });
  或者這樣:
  promise.success(function(data,status,config,headers){
  //處理成功的響應(yīng)
  });
  promise.error(function(data,status,hedaers,config){
  //處理失敗后的響應(yīng)
  });

then()方法與其他兩種方法的主要區(qū)別是,它會接收到完整的響應(yīng)對象,而success()和error()則會對響應(yīng)對象進行析構(gòu)。

3、快捷的get請求

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

get()方法返回HttpPromise對象。

還可以發(fā)送比如:delete/head/jsonp/post/put函數(shù)內(nèi)可接受參數(shù)具體參照148頁

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

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

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

也可以將$http當(dāng)做函數(shù)來使用,這時需要傳入一個設(shè)置對象,用來說明如何構(gòu)造XHR對象。

$http({
method:'GET',
url:'/api/users.json',
params:{
'username':'tan'
});

其中設(shè)置對象可以包含以下主要的鍵:

①method

可以是:GET/DELETE/HEAD/JSONP/POST/PUT

②url:絕對的或者相對的請求目標(biāo)

③params(字符串map或者對象)

這個鍵的值是一個字符串map或?qū)ο螅瑫晦D(zhuǎn)換成查詢字符串追加在URL后面。如果值不是字符串,會被JSON序列化。

比如這個:

//參數(shù)會轉(zhuǎn)為?name=ari的形式
$http({
params:{'name':'ari'}
});

④data(字符串或者對象)

這個對象中包含了將會被當(dāng)作消息體發(fā)送給服務(wù)器的數(shù)據(jù)。通常在發(fā)送POST請求時使用。

從AngularJS1.3開始,它還可以在POST請求里發(fā)送二進制數(shù)據(jù)。要發(fā)送一個blob對象,你可以簡單地通過使用data參數(shù)來傳遞它。

例如:

varblob=newBlob(['Helloworld'],{type:'text/plain'});
$http({
method:'POST',
url:'/',
data:blob
});

4、響應(yīng)對象

AngularJS傳遞給then()方法的響應(yīng)對象包含了四個屬性。

◇data:這個數(shù)據(jù)代表轉(zhuǎn)換過后的響應(yīng)體(如果定義了轉(zhuǎn)換的話)

◇status:響應(yīng)的HTTP狀態(tài)碼

◇headers:這個函數(shù)是頭信息的getter函數(shù),可以接受一個參數(shù),用來獲取對應(yīng)名字值

例如,用如下代碼獲取X-Auth-ID的值:

$http({
method:'GET',
url:'/api/users.json'
}).then(resp){
//讀取X-Auth-ID
resp.headers('X-Auth-ID');
});

◇config:這個對象是用來生成原始請求的完整設(shè)置對象。

◇statusText(字符串):這個字符串是響應(yīng)的HTTP狀態(tài)文本。

5、緩存HTTP請求

默認(rèn)情況下,$http服務(wù)不會對請求進行本地緩存。在發(fā)送單獨的請求時,我們可以通過向$http請求傳入一個布爾值或者一個緩存實例來啟用緩存。

$http.get('/api/users.json',{cache:true})
.success(function(data){})
.error(function(data){});

第一次發(fā)送請求時,$http服務(wù)會向/api/users.json發(fā)送一個GET請求。第二次發(fā)送同一個GET請求時,$http服務(wù)會從緩存中取回請求的結(jié)果,而不會真的發(fā)送一個HTTPGET請求。

在這個例子里,由于設(shè)置了啟用緩存,AngularJS默認(rèn)會使用$cacheFactory,這個服務(wù)是AngularJS在啟動時自動創(chuàng)建的。

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

以上就是扣丁學(xué)堂HTML5培訓(xùn)淺談AngularJS中$http服務(wù)用法的全部內(nèi)容,想要了解更多html5相關(guān)內(nèi)容的小伙伴可以登錄扣丁學(xué)堂官網(wǎng)查詢,扣丁學(xué)堂不僅有專業(yè)的老師和與時俱進的課程體系,還有大量的html5視頻教程供學(xué)員觀看學(xué)習(xí),想要學(xué)習(xí)html5的小伙伴快選擇專業(yè)的html5在線學(xué)習(xí)機構(gòu)扣丁學(xué)堂學(xué)習(xí)吧??鄱W(xué)堂H5技術(shù)交流群:559883758。


關(guān)注微信公眾號獲取更多學(xué)習(xí)資料



【關(guān)注微信公眾號獲取更多學(xué)習(xí)資料】



查看更多關(guān)于“HTML5開發(fā)技術(shù)資訊”的相關(guān)文章>>

標(biāo)簽: HTML5培訓(xùn) HTML5視頻教程 AngularJS HTML5在線視頻 HTML5從入門到精通

熱門專區(qū)

暫無熱門資訊

課程推薦

微信
微博
15311698296

全國免費咨詢熱線

郵箱:codingke@1000phone.com

官方群:148715490

北京千鋒互聯(lián)科技有限公司版權(quán)所有   北京市海淀區(qū)寶盛北里西區(qū)28號中關(guān)村智誠科創(chuàng)大廈4層
京ICP備2021002079號-2   Copyright ? 2017 - 2022
返回頂部 返回頂部