AngularJS通過$http和服務(wù)器通信詳解
$http
AngularJS提供了$http服務(wù)來同服務(wù)端進行通信,$http服務(wù)隊瀏覽器的XMLHttpRequest對象進行了封裝,讓我們可以以ajax的方式來從服務(wù)器請求數(shù)據(jù)。
在AngularJS中與遠程HTTP服務(wù)器交互時會用一個非常關(guān)鍵的服務(wù)-$http。
1、$http是angular中的一個核心服務(wù),利用瀏覽器的xmlhttprequest或者via JSONP對象與遠程HTTP服務(wù)器進行交互。
2、$http的使用方式和jquery提供的$.ajax操作比較相同,均支持多種method的請求,get、post、put、delete等。
3、$http的各種方式的請求更趨近于rest風(fēng)格。
4、在controller中可通過與$scope同樣的方式獲取$http對象,e.g. function controller($scope,$http){}
下面進行$http服務(wù)的使用說明,調(diào)用如下:
$http(config).success(function(data,status,headers,config){}).error(function(data,status,headers,config){});
$http服務(wù)是一個接受一個參數(shù)的函數(shù),參數(shù)的類型是對象,用來配置生成的http的請求,該函數(shù)返回一個promise對象
var promise = $http({ method:'GET', url:'/api/user.json' }); promise.then(function(resp){}, function(resp){})
$http請求的配置對象
$http()接受的配置對象可以包含以下屬性:
method:http請求方式,可以為GET,DELETE,HEAD,JSONP,POST,PUT
url:字符串,請求的目標(biāo)
params:字符串或者對象,會被轉(zhuǎn)換成為查詢字符串追加的url后面
data:在發(fā)送post請求時使用,作為消息體發(fā)送到服務(wù)器
headers:一個列表,每個元素都是一個函數(shù),返回http頭
xsrfHeaderName(字符串):保存XSFR令牌的http頭的名稱
xsrfCookieName:保存XSFR令牌的cookie名稱
transformRequest:函數(shù)或者函數(shù)數(shù)組,用來對http請求的請求體和頭信息進行轉(zhuǎn)換,并返回轉(zhuǎn)換后的結(jié)果。
transformResponse:函數(shù)或者函數(shù)數(shù)組,用來對http響應(yīng)的響應(yīng)體和頭信息進行轉(zhuǎn)換,并返回轉(zhuǎn)換后的結(jié)果。
cache:布爾類型或者緩存對象,設(shè)置之后angular會緩存get請求。
timeout:數(shù)值,延遲請求
responseType:字符串,響應(yīng)類型??梢詾閍rraybuffer, blob,document,json, text, moz-blob, moz-chunked-text, moz-chunked-
arraybuffer
$http請求的響應(yīng)對象
angular傳遞給then方法的響應(yīng)對象包括以下幾個屬性
data:轉(zhuǎn)換之后的響應(yīng)體
status:http響應(yīng)狀態(tài)碼
headers:頭信息
config:生成原始請求的設(shè)置對象
statusText:http響應(yīng)狀態(tài)的文本
攔截器
angular中通過攔截器我們可以從全局層面對請求以及響應(yīng)進行攔截。
使用攔截器之前,我們通過factory()
聲明一個服務(wù),然后通過$httpProvider
注冊攔截器。攔截器分為四種,兩種成功攔截器,兩種失敗攔截器。
angular.module('test', []).factory('testInterceptor', function($q){ var interceptor = { 'request':function(config){ return config; }, 'response':function(resp){ return response; }, 'requestError':function(rejection){ return $q.reject(rejection); }, 'responseError':function(rejection){ return rejection } } return interceptor; }) angular.module('test', []).config(function($httpProvider){ $httpProvider.interceptors.push('testInterceptor'); })
總結(jié)
以上就是這篇文章的全部內(nèi)容,希望能對大家的學(xué)習(xí)或者工作帶來一定的幫助,如果有疑問大家可以留言交流。
- JavaScript Window窗口對象屬性和使用方法
- swing分割窗口控件JSplitPane使用方法詳解
- javascript+html5+css3自定義彈出窗口效果
- JavaScript實現(xiàn)單擊網(wǎng)頁任意位置打開新窗口與關(guān)閉窗口的方法
- JS簡單實現(xiàn)父子窗口傳值功能示例【未使用iframe框架】
- Vue.js仿微信聊天窗口展示組件功能
- JS檢測window.open打開的窗口是否關(guān)閉
- 使用Ajax與服務(wù)器(JSON)通信實例
- AngularJS ngModel實現(xiàn)指令與輸入直接的數(shù)據(jù)通信
- 如何利用js在兩個html窗口間通信
相關(guān)文章
AngularJs的UI組件ui-Bootstrap之Tooltip和Popover
這篇文章主要介紹了AngularJs的UI組件ui-Bootstrap之Tooltip和Popover,tooltip和popover是輕量的、可擴展的、用于提示的指令。具有一定的參考價值,感興趣的小伙伴們可以參考一下2018-07-07發(fā)布Angular應(yīng)用至生產(chǎn)環(huán)境的方法
這篇文章主要介紹了發(fā)布Angular應(yīng)用至生產(chǎn)環(huán)境的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-12-12AngularJs $parse、$eval和$observe、$watch詳解
這篇文章主要介紹了AngularJs $parse、$eval和$observe、$watch的相關(guān)資料,需要的朋友可以參考下2016-09-09AngularJS $http模塊POST請求實現(xiàn)
本篇文章主要介紹了AngularJS $http模塊POST請求實現(xiàn),這里整理了詳細的代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-04-04angularjs點擊圖片放大實現(xiàn)上傳圖片預(yù)覽
這篇文章主要為大家詳細介紹了angularjs點擊圖片放大實現(xiàn)上傳圖片預(yù)覽的相關(guān)資料,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-02-02