簡介AngularJS中$http服務(wù)的用法
我們可以使用內(nèi)置的$http服務(wù)直接同外部進(jìn)行通信。$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對象
var promise=$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)對象進(jìn)行析構(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是可選的
var promise=$http.jsonp("/api/users.json?callback=JSON_CALLBACK");
4、也可以將$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ū)ο?,會被轉(zhuǎn)換成查詢字符串追加在URL后面。如果值不是字符串,會被JSON序列化。
比如這個:
//參數(shù)會轉(zhuǎn)為?name=ari的形式
$http({
params:{'name':'ari'}
});
④data(字符串或者對象)
這個對象中包含了將會被當(dāng)作消息體發(fā)送給服務(wù)器的數(shù)據(jù)。通常在發(fā)送POST請求時使用。
從AngularJS 1.3開始,它還可以在POST請求里發(fā)送二進(jìn)制數(shù)據(jù)。要發(fā)送一個blob對象,你可以簡單地通過使用data參數(shù)來傳遞它。
例如:
var blob=new Blob(['Hello world'],{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ù)不會對請求進(jìn)行本地緩存。在發(fā)送單獨(dú)的請求時,我們可以通過向$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ā)送一個HTTP GET請求。
在這個例子里,由于設(shè)置了啟用緩存,AngularJS默認(rèn)會使用$cacheFactory,這個服務(wù)是AngularJS在啟動時自動創(chuàng)建的。
如果想要對AngularJS使用的緩存進(jìn)行更多的自定義控制,可以向請求傳入一個自定義的緩存實例代替true。
下面給大家說下AngularJS $http知識。
AngularJS $http 是一個用于讀取web服務(wù)器上數(shù)據(jù)的服務(wù)。
$http.get(url) 是用于讀取服務(wù)器數(shù)據(jù)的函數(shù)。
AngularJS 實例
<div ng-app="myApp" ng-controller="customersCtrl">
<ul>
<li ng-repeat="x in names">
{{ x.Name + ', ' + x.Country }}
</li>
</ul>
</div>
<script>
var app = angular.module('myApp', []);
app.controller('customersCtrl', function($scope, $http) {
$http.get("http://www.runoob.com/try/angularjs/data/Customers_JSON.php")
.success(function(response) {$scope.names = response.records;});
});
</script>
相關(guān)文章
Angular4項目中添加i18n國際化插件ngx-translate的步驟詳解
這篇文章主要跟大家介紹了關(guān)于Angular4項目中添加i18n國際化插件ngx-translate的步驟,文中介紹的非常詳細(xì),對大家具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起看看吧。2017-07-07
angularJS的radio實現(xiàn)單項二選一的使用方法
下面小編就為大家分享一篇angularJS的radio實現(xiàn)單項二選一的使用方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-02-02
Angular?服務(wù)器端渲染應(yīng)用常見的內(nèi)存泄漏問題小結(jié)
這篇文章主要介紹了Angular?服務(wù)器端渲染應(yīng)用一個常見的內(nèi)存泄漏問題,主要包括屏幕閃爍問題,出現(xiàn)閃爍的原因,在于 Angular 不知道如何重用它在服務(wù)器上成功渲染的內(nèi)容,本文給大家介紹的非常詳細(xì),需要的朋友一起學(xué)習(xí)下吧2022-06-06
AngularJS之頁面跳轉(zhuǎn)Route實例代碼
本篇文章主要介紹了AngularJS之頁面跳轉(zhuǎn)Route ,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-03-03
在AngularJS應(yīng)用中實現(xiàn)一些動畫效果的代碼
這篇文章主要介紹了在AngularJS應(yīng)用中實現(xiàn)一些動畫效果的代碼,AngularJS是一款熱門的JavaScript庫,需要的朋友可以參考下2015-06-06

