咱們能夠使用內置的$http服務直接同外部進行通訊。$http服務只是簡單的封裝了瀏覽器原生的XMLHttpRequest對象。json
一、鏈式調用api
$http服務是隻能接受一個參數的函數,這個參數是一個對象,包含了用來生成HTTP請求的
配置內容。這個函數返回一個promise對象,具備success和error兩個方法。promise
$http({
url:'data.json',
method:'GET'
}).success(function(data,header,config,status){
//響應成功
}).error(function(data,header,config,status){
//處理響應失敗
});
二、返回一個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()則會對響應對
象進行析構。
三、快捷的get請求
①$http.get('/api/users.json');
函數
get()方法返回HttpPromise對象。post
還能夠發送好比:delete/head/jsonp/post/put 函數內可接受參數jsonp
②以再發送jsonp請求舉例說明: 爲了發送JSONP請求,其中url必須包含JSON_CALLBACK字樣。
jsonp(url,config) 其中config是可選的
var promise=$http.jsonp("/api/users.json?callback=JSON_CALLBACK");
url
四、也能夠將$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請求時使用。
它還能夠在POST請求裏發送二進制數據。要發送一個blob對象,你能夠簡單地經過使用data參數來傳遞它。
例如:
var blob=new Blob(['Hello world'],{type:'text/plain'});
$http({
method:'POST',
url:'/',
data:blob
});
四、響應對象
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狀態文本。五、緩存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。