http://www./kf/201506/405137.html 我們可以使用內(nèi)置的$http服務(wù)直接同外部進(jìn)行通信。$http服務(wù)只是簡(jiǎn)單的封裝了瀏覽器原生的XMLHttpRequest對(duì)象。 1、鏈?zhǔn)秸{(diào)用 $http服務(wù)是只能接受一個(gè)參數(shù)的函數(shù),這個(gè)參數(shù)是一個(gè)對(duì)象,包含了用來(lái)生成HTTP請(qǐng)求的配置內(nèi)容。這個(gè)函數(shù)返回一個(gè)promise對(duì)象,具有success和error兩個(gè)方法。 $http({ 2、返回一個(gè)promise對(duì)象 var promise=$http({ 由于$http方法返回一個(gè)promise對(duì)象,我們可以在響應(yīng)返回時(shí)用then方法來(lái)處理回調(diào)。如果 使用then方法,會(huì)得到一個(gè)特殊的參數(shù),它代表了相應(yīng)對(duì)象的成功或失敗信息,還可以接受兩個(gè) 可選的函數(shù)作為參數(shù)?;蛘呖梢允褂胹uccess和error回調(diào)代替。 promise.then(function(resp){ 或者這樣: promise.success(function(data,status,config,headers){ then()方法與其他兩種方法的主要區(qū)別是,它會(huì)接收到完整的響應(yīng)對(duì)象,而success()和error()則會(huì)對(duì)響應(yīng)對(duì) 象進(jìn)行析構(gòu)。 3、快捷的get請(qǐng)求 ①$http.get('/api/users.json'); get()方法返回HttpPromise對(duì)象。 還可以發(fā)送比如:delete/head/jsonp/post/put 函數(shù)內(nèi)可接受參數(shù)具體參照148頁(yè) ②以再發(fā)送jsonp請(qǐng)求舉例說(shuō)明: 為了發(fā)送JSONP請(qǐng)求,其中url必須包含JSON_CALLBACK字樣。 jsonp(url,config) 其中config是可選的 var promise=$http.jsonp("/api/users.json?callback=JSON_CALLBACK"); 4、也可以將$http當(dāng)做函數(shù)來(lái)使用,這時(shí)需要傳入一個(gè)設(shè)置對(duì)象,用來(lái)說(shuō)明如何構(gòu)造XHR對(duì)象。 $http({其中設(shè)置對(duì)象可以包含以下主要的鍵: ①method 可以是:GET/DELETE/HEAD/JSONP/POST/PUT ②url:絕對(duì)的或者相對(duì)的請(qǐng)求目標(biāo) ③params(字符串map或者對(duì)象) 這個(gè)鍵的值是一個(gè)字符串map或?qū)ο?,?huì)被轉(zhuǎn)換成查詢字符串追加在URL后面。如果值不是字符串,會(huì)被JSON序列化。 比如這個(gè): //參數(shù)會(huì)轉(zhuǎn)為?name=ari的形式 $http({ params:{'name':'ari'} }); ④data(字符串或者對(duì)象) 這個(gè)對(duì)象中包含了將會(huì)被當(dāng)作消息體發(fā)送給服務(wù)器的數(shù)據(jù)。通常在發(fā)送POST請(qǐng)求時(shí)使用。 從AngularJS 1.3開(kāi)始,它還可以在POST請(qǐng)求里發(fā)送二進(jìn)制數(shù)據(jù)。要發(fā)送一個(gè)blob對(duì)象,你可以簡(jiǎn)單地通過(guò)使用data參數(shù)來(lái)傳遞它。 例如: var blob=new Blob(['Hello world'],{type:'text/plain'}); 4、響應(yīng)對(duì)象 AngularJS傳遞給then()方法的響應(yīng)對(duì)象包含了四個(gè)屬性。 ◇data 這個(gè)數(shù)據(jù)代表轉(zhuǎn)換過(guò)后的響應(yīng)體(如果定義了轉(zhuǎn)換的話) ◇status 響應(yīng)的HTTP狀態(tài)碼 ◇headers 這個(gè)函數(shù)是頭信息的getter函數(shù),可以接受一個(gè)參數(shù),用來(lái)獲取對(duì)應(yīng)名字值 例如,用如下代碼獲取X-Auth-ID的值: $http({ ◇config 這個(gè)對(duì)象是用來(lái)生成原始請(qǐng)求的完整設(shè)置對(duì)象。 ◇statusText(字符串) 這個(gè)字符串是響應(yīng)的HTTP狀態(tài)文本。 5、緩存HTTP請(qǐng)求 默認(rèn)情況下,$http服務(wù)不會(huì)對(duì)請(qǐng)求進(jìn)行本地緩存。在發(fā)送單獨(dú)的請(qǐng)求時(shí),我們可以通過(guò)向$http請(qǐng)求傳入一個(gè)布爾值或者一個(gè)緩存實(shí)例來(lái)啟用緩存。 $http.get('/api/users.json',{ cache: true }) .success(function(data) {}) .error(function(data) {}); 第一次發(fā)送請(qǐng)求時(shí),$http服務(wù)會(huì)向/api/users.json發(fā)送一個(gè)GET請(qǐng)求。第二次發(fā)送同一個(gè)GET請(qǐng)求時(shí),$http服務(wù)會(huì)從緩存中取回請(qǐng)求的結(jié)果,而不會(huì)真的發(fā)送一個(gè)HTTP GET請(qǐng)求。 在這個(gè)例子里,由于設(shè)置了啟用緩存,AngularJS默認(rèn)會(huì)使用$cacheFactory,這個(gè)服務(wù)是AngularJS在啟動(dòng)時(shí)自動(dòng)創(chuàng)建的。 如果想要對(duì)AngularJS使用的緩存進(jìn)行更多的自定義控制,可以向請(qǐng)求傳入一個(gè)自定義的緩存實(shí)例代替true。 |
|
來(lái)自: 瑤疏影 > 《AngularJS》