您好,欢迎访问一九零五行业门户网

JS如何实现Ajax的请求函数

这次给大家带来js如何实现ajax的请求函数,js实现ajax请求函数的注意事项有哪些,下面就是实战案例,一起来看一下。
一般我们写网页的时候,如果用到 ajax 请求服务器,都是使用 jquery 等已经封装好的库来调用,比较简单。
但是一般这些库的功能很多,引入了太多我们用不到的东西,如果我们需要写一个功能单一,简单的页面,完全用不到引用如此庞大的库文件。
我们可以简单实现一个自己的 ajax 请求功能,具体的代码如下:
var ajax = {}; ajax.x = function () {  if (typeof xmlhttprequest !== 'undefined') {  return new xmlhttprequest();  }  var versions = [  msxml2.xmlhttp.6.0,  msxml2.xmlhttp.5.0,  msxml2.xmlhttp.4.0,  msxml2.xmlhttp.3.0,  msxml2.xmlhttp.2.0,  microsoft.xmlhttp  ];  var xhr;  for (var i = 0; i < versions.length; i++) { try { xhr = new activexobject(versions[i]); break; } catch (e) { } } return xhr; }; ajax.send = function (url, method, data, success,fail,async) { if (async === undefined) { async = true; } var x = ajax.x(); x.open(method, url, async); x.onreadystatechange = function () { if (x.readystate == 4) { var status = x.status; if (status >= 200 && status < 300) {  success && success(x.responsetext,x.responsexml)  } else {  fail && fail(status);  }  }  };  if (method == 'post') {  x.setrequestheader('content-type', 'application/x-www-form-urlencoded');  }  x.send(data) }; ajax.get = function (url, data, callback, fail, async) {  var query = [];  for (var key in data) {  query.push(encodeuricomponent(key) + '=' + encodeuricomponent(data[key]));  }  ajax.send(url + (query.length ? '?' + query.join('&') : ''), 'get', null, callback, fail, async) }; ajax.post = function (url, data, callback, fail, async) {  var query = [];  for (var key in data) {  query.push(encodeuricomponent(key) + '=' + encodeuricomponent(data[key]));  }  ajax.send(url,'post', query.join('&'), callback, fail, async) };
使用方法: get
ajax.get('/test.php', {foo: 'bar'}, function(response,xml) {  //success }, function(status){  //fail }); post ajax.post('/test.php', {foo: 'bar'}, function(response,xml) {  //succcess },function(status){  //fail });
这里需要注意一个问题,如果我们想要发送类似
var sendcmd = ?op_code= + code + &op_cmd= + cmd; ajax.post('/control' + sendcmd,'',function(response,xml) {  console.log('success'); }, function(status){  console.log('failed:' + status); });
相信看了本文案例你已经掌握了方法,更多精彩请关注其它相关文章!
推荐阅读:
js实现计算器功能最简洁方法
angular实现表格过滤,删除功能
以上就是js如何实现ajax的请求函数的详细内容。
其它类似信息

推荐信息