簡介AngularJS中$http服務的用法_AngularJS

來源:互聯網
上載者:User

我們可以使用內建的$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(resp){//resp是一個響應對象},function(resp){//帶有錯誤資訊的resp});

或者這樣:

promise.success(function(data,status,config,headers){//處理成功的響應});promise.error(function(data,status,hedaers,config){//處理失敗後的響應});

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

3、快捷的get請求

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

get()方法返回HttpPromise對象。

還可以發送比如:delete/head/jsonp/post/put 函數內可接受參數具體參照148頁

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

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

var promise=$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請求時使用。

從AngularJS 1.3開始,它還可以在POST請求裡發送位元據。要發送一個blob對象,你可以簡單地通過使用data參數來傳遞它。
例如:

var blob=new Blob(['Hello world'],{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-IDresp.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。

下面給大家說下AngularJS $http知識。

AngularJS $http 是一個用於讀取web伺服器上資料的服務。

$http.get(url) 是用於讀取伺服器資料的函數。

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>

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.