js - 封装ajax

简介: 简单封装/使用promise封装ajax/封装:$.ajax()
+关注继续查看

简单封装ajax

发送一个带有参数的 post 请求

  function ajax(url, method, data, successCallback, errorCallback) {
  var xhr = new XMLHttpRequest();

  xhr.onreadystatechange = function() {
    if (xhr.readyState === XMLHttpRequest.DONE) {
      if (xhr.status === 200) {
        successCallback(xhr.responseText);
      } else {
        errorCallback(xhr.statusText);
      }
    }
  };

  xhr.open(method, url, true);

  if (method === 'POST') {
    xhr.setRequestHeader('Content-Type', 'application/json');
    xhr.send(JSON.stringify(data));
  } else {
    xhr.send();
  }
}

使用promise封装ajax

  function ajax(url, method, data) {
  return new Promise(function(resolve, reject) {
    var xhr = new XMLHttpRequest();

    xhr.onreadystatechange = function() {
      if (xhr.readyState === XMLHttpRequest.DONE) {
        if (xhr.status === 200) {
          resolve(xhr.responseText);
        } else {
          reject(xhr.statusText);
        }
      }
    };

    xhr.open(method, url, true);

    if (method === 'POST') {
      xhr.setRequestHeader('Content-Type', 'application/json');
      xhr.send(JSON.stringify(data));
    } else {
      xhr.send();
    }
  });
}

封装:$.ajax()

  function ajax(url, method, data, successCallback, errorCallback) {
  $.ajax({
    url: url,
    type: method,
    data: JSON.stringify(data),
    contentType: 'application/json',
    success: function(response) {
      successCallback(response);
    },
    error: function(xhr, status, error) {
      errorCallback(error);
    }
  });
}
相关文章
|
16天前
|
JavaScript 前端开发
原生js实现ajax请求带请求头header
原生js实现ajax请求带请求头header
|
20天前
|
JavaScript 前端开发
js实现原生ajax
js实现原生ajax
|
22天前
|
JavaScript 前端开发
原生JS实现Ajax下载文件
原生JS实现Ajax下载文件
|
1月前
|
XML 前端开发 JavaScript
js创建 ajax 过程
js创建 ajax 过程
12 0
|
3月前
|
前端开发 JavaScript
原生js发送ajax请求---ajax请求篇(一)
在原生js中我们使用的是XMLHttpRequest对象来发送ajax请求
64 0
|
3月前
|
XML 前端开发 JavaScript
Ajax介绍以及工作原理和实现详解(JS实现Ajax 和 JQ实现Ajax)
Ajax介绍以及工作原理和实现详解(JS实现Ajax 和 JQ实现Ajax)
83 0
|
5月前
|
JavaScript 前端开发
ajax未分装前JS代码形式
ajax未分装前JS代码形式
55 0
|
10月前
|
XML 前端开发 JavaScript
简述Ajax,以及使用原生js书写Ajax案例
简述Ajax,以及使用原生js书写Ajax案例
96 0
|
11月前
|
XML 前端开发 JavaScript
JS案例:ajax获取图片列表
JS案例:ajax获取图片列表
139 0
JS案例:ajax获取图片列表
|
11月前
|
前端开发 JavaScript
JS案例:Ajax实现简单局域网聊天室
JS案例:Ajax实现简单局域网聊天室
155 0
相关产品
云迁移中心
推荐文章
更多