欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

簡(jiǎn)介AngularJS中$http服務(wù)的用法

 更新時(shí)間:2016年02月06日 15:26:23   投稿:mrr  
我們可以使用內(nèi)置的$http服務(wù)直接同外部進(jìn)行通信。$http服務(wù)只是簡(jiǎn)單的封裝了瀏覽器原生的XMLHttpRequest對(duì)象。接下來(lái)通過本文給大家簡(jiǎn)單介紹angularjs中http服務(wù)的用法,喜歡的朋友可以參考下

我們可以使用內(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({
url:'data.json',
method:'GET'
}).success(function(data,header,config,status){
//響應(yīng)成功
}).error(function(data,header,config,status){
//處理響應(yīng)失敗
});

2、返回一個(gè)promise對(duì)象

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

由于$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){
//resp是一個(gè)響應(yīng)對(duì)象
},function(resp){
//帶有錯(cuò)誤信息的resp
});

或者這樣:

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

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({
method:'GET',
url:'/api/users.json',
params:{
'username':'tan'
});

其中設(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開始,它還可以在POST請(qǐng)求里發(fā)送二進(jìn)制數(shù)據(jù)。要發(fā)送一個(gè)blob對(duì)象,你可以簡(jiǎn)單地通過使用data參數(shù)來(lái)傳遞它。
例如:

var blob=new Blob(['Hello world'],{type:'text/plain'});
$http({
method:'POST',
url:'/',
data:blob
});

4、響應(yīng)對(duì)象

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

data

這個(gè)數(shù)據(jù)代表轉(zhuǎn)換過后的響應(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({
method: 'GET',
url: '/api/users.json'
}).then (resp) {
// 讀取X-Auth-ID
resp.headers('X-Auth-ID');
});

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í),我們可以通過向$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。

下面給大家說(shuō)下AngularJS $http知識(shí)。

AngularJS $http 是一個(gè)用于讀取web服務(wù)器上數(shù)據(jù)的服務(wù)。

$http.get(url) 是用于讀取服務(wù)器數(shù)據(jù)的函數(shù)。

AngularJS 實(shí)例

<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)文章

  • AngularJS基礎(chǔ) ng-submit 指令簡(jiǎn)單示例

    AngularJS基礎(chǔ) ng-submit 指令簡(jiǎn)單示例

    本文主要介紹AngularJS ng-submit 指令,這里對(duì)ng-submit 指令的基礎(chǔ)資料做了詳細(xì)介紹整理,并附有代碼示例,有需要的小伙伴可以參考下
    2016-08-08
  • Angularjs 動(dòng)態(tài)添加指令并綁定事件的方法

    Angularjs 動(dòng)態(tài)添加指令并綁定事件的方法

    本篇文章主要介紹了Angularjs 動(dòng)態(tài)添加指令并綁定事件的方法,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來(lái)看看吧
    2017-04-04
  • 詳解angular 中的自定義指令之詳解API

    詳解angular 中的自定義指令之詳解API

    本篇文章主要介紹了angular 中的自定義指令之詳解API,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來(lái)看看吧
    2017-06-06
  • Angular 利用路由跳轉(zhuǎn)到指定頁(yè)面的指定位置方法

    Angular 利用路由跳轉(zhuǎn)到指定頁(yè)面的指定位置方法

    今天小編就為大家分享一篇Angular 利用路由跳轉(zhuǎn)到指定頁(yè)面的指定位置方法,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過來(lái)看看吧
    2018-08-08
  • AngularJS遍歷獲取數(shù)組元素的方法示例

    AngularJS遍歷獲取數(shù)組元素的方法示例

    這篇文章主要介紹了AngularJS遍歷獲取數(shù)組元素的方法,涉及AngularJS簡(jiǎn)單的數(shù)組遍歷及元素獲取相關(guān)操作技巧,需要的朋友可以參考下
    2017-11-11
  • AngularJS中的Directive實(shí)現(xiàn)延遲加載

    AngularJS中的Directive實(shí)現(xiàn)延遲加載

    延遲加載通常是直到用戶交互時(shí)才加載,那么如何實(shí)現(xiàn)延時(shí)加載的呢?下面通過本文一起學(xué)習(xí)AngularJS中的Directive實(shí)現(xiàn)延遲加載,對(duì)angularjs延時(shí)加載相關(guān)知識(shí)感興趣的朋友一起學(xué)習(xí)吧
    2016-01-01
  • AngularJS中監(jiān)視Scope變量以及外部調(diào)用Scope方法

    AngularJS中監(jiān)視Scope變量以及外部調(diào)用Scope方法

    在AngularJS中,有時(shí)候需要監(jiān)視Scope中的某個(gè)變量,因?yàn)樽兞康母淖儠?huì)影響一些界面元素的顯示,接下來(lái)通過本文給大家介紹AngularJS中監(jiān)視Scope變量以及外部調(diào)用Scope方法,需要的朋友參考下吧
    2016-01-01
  • angularJS 指令封裝回到頂部示例詳解

    angularJS 指令封裝回到頂部示例詳解

    本篇文章主要介紹了angularJS 指令封裝回到頂部示例詳解,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來(lái)看看吧
    2017-01-01
  • AngularJS之頁(yè)面跳轉(zhuǎn)Route實(shí)例代碼

    AngularJS之頁(yè)面跳轉(zhuǎn)Route實(shí)例代碼

    本篇文章主要介紹了AngularJS之頁(yè)面跳轉(zhuǎn)Route ,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來(lái)看看吧
    2017-03-03
  • AngularJS實(shí)現(xiàn)圖片上傳和預(yù)覽功能的方法分析

    AngularJS實(shí)現(xiàn)圖片上傳和預(yù)覽功能的方法分析

    這篇文章主要介紹了AngularJS實(shí)現(xiàn)圖片上傳和預(yù)覽功能的方法,結(jié)合HTML5實(shí)例形式對(duì)比分析了AngularJS圖片上傳的相關(guān)操作技巧與注意事項(xiàng),需要的朋友可以參考下
    2017-11-11

最新評(píng)論