xhr以及用法見以前的文章
var _headerConfig = {}; if(url.indexOf('getcaptcha') !== -1) { _headerConfig = { Accept: 'image/png', responseType: 'arraybuffer', } } else if(url.indexOf('files/upload') !== -1) { _headerConfig = { 'Content-Type': 'multipart/form-data', responseType: 'json', } } else { _headerConfig = { 'Content-Type': 'application/json', Accept: 'application/json', responseType: 'json', } }
if("method" in options) { options.method = options.method.toUpperCase(); } else { options.method = "GET"; } if(options.method !== "GET") { if(!(options.params instanceof FormData)) { options.params = JSON.stringify(options.params); } }
this.xhr.open(options.method, url, true); for(var _i in _headerConfig) { if(_i === 'responseType') { this.xhr.responseType = _headerConfig[_i]; } else { this.xhr.setRequestHeader(_i, _headerConfig[_i]); } } if(token) { this.xhr.setRequestHeader("token", token); } this.xhr.send(options.params);
這個問題結合鏈式編程一度的卡了好久。javascript
ajax.prototype.complete = function(completeFunction) { this.xhr.onreadystatechange = function(e) { if(this.readyState === 4) { completeFunction(this); } } return this; }
在項目中常常須要將request進行封裝,使用ajax類發起請求。拼接請求的地址函數。
var requstUrl = { baseURL: URL, API: { NEWS: '/news', LOGIN: '/', }, // api爲API中的參數,用於拼接url // method爲API後的地址,用於拼接url最後面的東西。 // params爲get請求須要的參數 createUrl: function(api, method, params) { var _requestUrl = this.baseURL + this.API[api] + method; if(params) { for(var i of params) { _requestUrl += (_requestUrl.indexOf("?") == -1 ? "?" : "&"); _requestUrl += name + "=" + value; } } return _requestUrl; } }
function handleRequest() { } // get請求帶參數。 handleRequest.prototype.getDataUseGet = function(api, method, params) { var _url; var ajax = new Ajax(); var token = sessionStorage.getItem('token'); if(params) { _url = requstUrl.createUrl(api, method, params); } else { _url = requstUrl.createUrl(api, method); } return ajax.request(_url, { method: 'GET', params: params }, token); } // get請求不帶token handleRequest.prototype.getDataUseGetWithoutToken = function(api, method, params) { var _url; var ajax = new Ajax(); if(params) { _url = requstUrl.createUrl(api, method, params); } else { _url = requstUrl.createUrl(api, method); } return ajax.request(_url, { method: 'GET', params: params }); } // post請求帶token handleRequest.prototype.getDataUsePost = function(api, method, params) { var _url = requstUrl.createUrl(api, method); var token = sessionStorage.getItem('token'); var ajax = new Ajax(); console.log(createAjaxObj(_url, { method: 'POST', params: params }, token)); return ajax.request(_url, { method: 'POST', params: params }, token); } // post請求不帶token handleRequest.prototype.getDataUsePostWithOutToken = function(api, method, params) { var _url = requstUrl.createUrl(api, method); var ajax = new Ajax(); return ajax.request(_url, { method: 'POST', params: params }); } // put請求帶token handleRequest.prototype.getDataUsePut = function(api, method, params) { var _url = requstUrl.createUrl(api, method); var token = sessionStorage.getItem('token'); var ajax = new Ajax(); return ajax.request(_url, { method: 'PUT', params: params }, token); } // put請求不帶token handleRequest.prototype.getDataUsePutWithOutToken = function(api, method, params) { var _url = requstUrl.createUrl(api, method); var ajax = new Ajax(); return ajax.request(_url, { method: 'PUT', params: params }); } // delete請求帶token handleRequest.prototype.deleteData = function(api, method, params) { var _url = requstUrl.createUrl(api, method); var token = sessionStorage.getItem('token'); var ajax = new Ajax(); return ajax.request(_url, { method: 'DELETE', params: params }, token); }
這個方法感受能夠再次進行封裝。
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title></title> </head> <body> </body> <script src="ip.js" type="text/javascript"></script> <script src="xhr.js" type="text/javascript"></script> <script src="request.js" type="text/javascript"></script> <script type="text/javascript"> var data = { "captcha": "string", "password": "string", "username": "string" }; var test = new handleRequest(); test.getDataUsePostWithOutToken('LOGIN', 'login',data).complete(function(result) { console.log(result) }) </script> </html>
成功發起請求。html
完整代碼點擊查看java
以上。git