91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么在AngularJS中使用$http服務

發布時間:2021-04-02 17:37:25 來源:億速云 閱讀:159 作者:Leah 欄目:web開發

怎么在AngularJS中使用$http服務?相信很多沒有經驗的人對此束手無策,為此本文總結了問題出現的原因和解決方法,通過這篇文章希望你能解決這個問題。

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-ID
resp.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中使用$http服務的方法了嗎?如果還想學到更多技能或想了解更多相關內容,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

内黄县| 凤台县| 天水市| 南漳县| 武鸣县| 闸北区| 五台县| 肥乡县| 武城县| 宜良县| 潜山县| 定边县| 宿松县| 长汀县| 沁阳市| 旺苍县| 防城港市| 循化| 商水县| 卓尼县| 龙里县| 拜泉县| 瓦房店市| 巴彦县| 塔河县| 西丰县| 杭州市| 定州市| 桂阳县| 滁州市| 天等县| 河曲县| 毕节市| 新郑市| 吉隆县| 新昌县| 玛纳斯县| 胶州市| 嘉义县| 龙口市| 隆昌县|