第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號安全,請及時綁定郵箱和手機立即綁定
已解決430363個問題,去搜搜看,總會有你想問的

在angularjs中怎樣自定義http請求

在angularjs中怎樣自定義http請求

慕運維8079593 2019-03-27 17:17:28
在angularjs中怎樣自定義http請求
查看完整描述

2 回答

?
慕森王

TA貢獻(xiàn)1777條經(jīng)驗 獲得超3個贊

我們可以使用內(nèi)置的$http服務(wù)直接同外部進行通信。$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ù)。或者可以使用success和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)對
象進行析構(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ā)送二進制數(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ù)不會對請求進行本地緩存。在發(fā)送單獨的請求時,我們可以通過向$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使用的緩存進行更多的自定義控制,可以向請求傳入一個自定義的緩存實例代替true。



查看完整回答
反對 回復(fù) 2019-03-30
?
一只斗牛犬

TA貢獻(xiàn)1784條經(jīng)驗 獲得超2個贊

我們可以使用內(nèi)置的$http服務(wù)直接同外部進行通信。$http服務(wù)只是簡單的封裝了瀏覽器原生的XMLHttpRequest對象。$http服務(wù)是只能接受一個參數(shù)的函數(shù),這個參數(shù)是一個對象,包含了用來生成HTTP請求的配置內(nèi)容。這個函數(shù)返回一個promise對象,具有success和error兩個方法。

具體如下:

1、簡介

編程是編寫程序的中文簡稱,就是讓計算機代為解決某個問題,對某個計算體系規(guī)定一定的運算方式,是計算體系按照該計算方式運行,并最終得到相應(yīng)結(jié)果的過程。

為了使計算機能夠理解人的意圖,人類就必須將需解決的問題的思路、方法和手段通過計算機能夠理解的形式告訴計算機,使得計算機能夠根據(jù)人的指令一步一步去工作,完成某種特定的任務(wù)。這種人和計算體系之間交流的過程就是編程。

2、匯編程序

匯編程序。使用匯編語言編寫計算機程序,程序員仍然需要十分熟悉計算機系統(tǒng)的硬件結(jié)構(gòu),所以從程序設(shè)計本身上來看仍然是低效率的、繁瑣的。但正是由于匯編語言與計算機硬件系統(tǒng)關(guān)系密切,在某些特定的場合,如對時空效率要求很高的系統(tǒng)核心程序以及實時控制程序等,迄今為止匯編語言仍然是十分有效的程序設(shè)計工具。

3、執(zhí)行原理

計算機對除機器語言以外的源程序不能直接識別、理解和執(zhí)行,都必須通過某種方式轉(zhuǎn)換為計算機能夠直接執(zhí)行的。這種將高級編程硬件程序設(shè)計語言編寫的源程序轉(zhuǎn)換到機器目標(biāo)程序的方式有兩種:解釋方式和編譯方式。


 


查看完整回答
反對 回復(fù) 2019-03-30
  • 2 回答
  • 0 關(guān)注
  • 848 瀏覽

添加回答

舉報

0/150
提交
取消
微信客服

購課補貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動學(xué)習(xí)伙伴

公眾號

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號