Jquery Ajax简单封装(集中错误、请求loading处理)

对Jquery Ajax做了简单封装,错误处理,请求loading等,运用到项目中集中处理会很方便。

技术层面没有什么好说的,请求是用jquery ajax,弹出层是用layer,大家可以随意替换。比如你用weui,也可以$.toast()等。
用jquery的Deferred来传递成功或失败的状态。

/*
*封装一个自己的ajax函数
*有5个参数,最后一个参数可选
*
* @param method(必选) 请求类型 get 和 post
* @param url(必选) 请求的url地址 相同域名下的页面(此函数不支持跨域请求)
* @param data(必选) 请求协带的数据 以js对象的形式定义,如:{name:'张三'}
* @param callback(必选) 回调函数,可接收一个参数,这个参数就是服务器响应的数据
* @param type(可选) 指定服务器响应的数据类型(可选值:json,xml,text),如果是json模式,则使用json解析数据,默认为text普通字符串
*/
//在一个js文件中引入另一个js文件
var new_element = document.createElement("script");
new_element.setAttribute("type", "text/javascript");
new_element.setAttribute("src", "https:////layui.hcwl520.com.cn/layui/layui.js?v=201811010202");
document.body.appendChild(new_element); // js中引入一个css文件
var css = document.createElement('link');
css.rel = 'stylesheet';
css.href = 'https://layui.hcwl520.com.cn/layui/css/layui.css?v=201811010202';
document.head.appendChild(css); function myAjax(method, url, data, callback, type) {
var baseUrl = "xxxxx";
url = baseUrl + url
// 登录信息
var login = sessionStorage.getItem("LoginUser");
if (login != null) {
var loginList = JSON.parse(sessionStorage.getItem("LoginUser"))
// 用户token
var token = loginList.token_sc
}
//创建兼容 XMLHttpRequest 对象
var xhr;
if (window.XMLHttpRequest) {//IE7+, Firefox, Chrome, Opera, Safari
xhr = new XMLHttpRequest();
} else {// code for IE6, IE5
xhr = new ActiveXObject("Microsoft.XMLHTTP");
} //给请求添加状态变化事件处理函数
xhr.onreadystatechange = function () {
//判断状态码
if (xhr.status == 200 && xhr.readyState == 4) {
//根据type参数,判断返回的内容需要进行怎样的处理
if (type == 'json') {
//获得 json 形式的响应数据,并使用parse方法解析
var res = JSON.parse(xhr.responseText);
} else if (type == 'xml') {
//获得 XML 形式的响应数据
var res = responseXML;
} else if (type == 'str') {
//获得字符串形式的响应数据
var res = xhr.responseText;
} else {
//获得 json 形式的响应数据,并使用parse方法解析
var res = JSON.parse(xhr.responseText);
}
//调用回调函数,并将响应数据传入回调函数
callback(res); var xhrObj = JSON.parse(xhr.response)
// console.log(xhrObj.error_code)
// 回调状态码,根据具体情况来,可以做一些集中loading处理之类的
layui.use('layer', function () {
//loading层
var loading = layer.load(2, {
shade: [0.1, '#fff'], //0.1透明度的白色背景
});
if (xhrObj.error_code === 2011) {
layer.close(loading);
layer.msg(xhrObj.message, {
icon: 5
});
} else if (xhrObj.error_code === 1100) {
layer.close(loading);
layer.msg(xhrObj.message, {
icon: 5
});
} else if (xhrObj.error_code === 0) {
layer.close(loading);
}
}); }
}; //判断data是否有数据
var param = '';
//这里使用stringify方法将js对象格式化为json字符串
if (JSON.stringify(data) != '{}') {
url += '?';
for (var i in data) {
param += i + '=' + data[i] + '&'; //将js对象重组,拼接成url参数存入param变量中
}
//使用slice函数提取一部分字符串,这里主要是为了去除拼接的最后一个&字符
//slice函数:返回一个新的字符串。包括字符串从 start 开始(包括 start)到 end 结束(不包括 end)为止的所有字符。
param = param.slice(0, param.length - 1);
} //判断method是否为get
if (method == "get") {
//是则将数据拼接在url后面
url = url + param;
} //初始化请求
xhr.open(method, url, true); //如果method == post
if (method == "post") {
xhr.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
//发送请求
xhr.send(param);
} else {
//发送请求
xhr.send(null);
} }
调用实例(引入上面代码):
<!DOCTYPE html>
<html lang="en"> <head>
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
<meta http-equiv="X-UA-Compatible" content="ie=edge">
<title>Document</title> </head> <body>
<div>
<input type="text" placeholder="手机号" id="phone">
<input type="password" placeholder="密码" id="pass">
<button onclick="login()">登录</button>
</div>
<script src="./lib/js/jquery-3.4.0.min.js"></script>
<script src="./config/api.js"></script>
<script>
function login() {
var phone = $('#phone').val()
var pass = $('#pass').val()
console.log("登录中..." + "手机号:" + phone)
console.log("登录中..." + "密码:" + pass)
myAjax('post', '/members/login', { phone: phone, pass: pass }, function (res) {
console.log(res);
}); }
</script>
</body> </html>
												

Jquery Ajax简单封装(集中错误、请求loading处理)的更多相关文章

  1. JQuery - Ajax和Tomcat跨域请求问题解决方法!

    在JQuery里面使用Ajax和Tomcat服务器之间进行数据交互,遇到了跨域请求问题,无法成功得到想要的数据! 错误信息部分截图: 通过错误信息判断知道已经发生在Ajax跨域请求问题了! 当前Tom ...

  2. Jquery.ajax 详细解释 通过Http请求加载远程数据

    首先请看一个Jquery.ajax的例子 $.ajax({ type: "GET", url: "/api/SearchApi/GetResults", dat ...

  3. jQuery ajax的jsonp跨域请求

    一直在听“跨域跨域”,但是什么是跨域呢?今天做了一些了解.(利用jQuery的jsonp) jQuery使用JSONP跨域 JSONP跨域是利用script脚本允许引用不同域下的js实现的,将回调方法 ...

  4. jQuery Ajax 简单的实现跨域请求

    html 代码清单: <script type="text/javascript" src="http://www.youxiaju.com/js/jquery-1 ...

  5. ajax简单封装

    var xmlhttp = window.XMLHttpRequest ? new XMLHttpRequest() : new ActiveXObject('Microsoft.XMLHTTP'); ...

  6. php+JQuery+Ajax简单实现页面异步刷新 (转)

    页面显示如下: JQueryAjax.html中的代码如下(用的较为简单的$.post) <html> <head> <meta charset="UTF-8& ...

  7. jquery ajax中error返回错误解决办法

    转自:https://www.jb51.net/article/72198.htm 进入百度搜索此问题,发现有人这么说了一句 Jquery中的Ajax的async默认是true(异步请求),如果想一个 ...

  8. C# .net Jquery ajax 简单示例

    jquery中ajax相信大家都不陌生,这里只写个简单例子示意用法,详细后续再写. 在html中按钮事件中添加如下js var param = "data=" + escape($ ...

  9. jquery ajax简单书写

    占时无法显示该内容,请稍后再试 $.ajax({ url:"http://v.juhe.cn/weather/index", data:{cityname:"苏州&quo ...

随机推荐

  1. CSS盒子模型(框模型)

     一.如何理解盒子模型  盒子模型(框模型)是css部分非常重要的一部分知识,CSS在处理网页的时候,认为每个元素都处在一个不可见的盒子中.盒子模型的构想,把所有的元素都想象成盒子,那么对网页进行布局 ...

  2. 解决json不能解析换行问题

    今天遇到一个问题,当我读取数据库中某条带换行的数据时,解析错误. 解决方法是在存入数据库时对数据做处理,把换行换成其他字符.代码如下: remark = remark.replace(/\n/g,&q ...

  3. <知识整理>2019清北学堂提高储备D4

    今天主要讲一下数学的知识. 一.进制转换: 十进制到k进制:短除法:顺除至0,逆序取余. k进制转十进制:乘权相加. 常见进制:四进制(对应2位二进制).八进制(对应3位二进制).十六进制(对应4位二 ...

  4. Mysql索引深入理解

    一.  引言 Mysql 我们平常用的很多,了解的很多,今天别的不说,直接说mysql的底层是什么,说到底层,就想到数据结构,那么,mysql的数据结构是什么呢? 是B + tree .那么数据库中的 ...

  5. [ethereum源码分析](1) dubug环境搭建

    前言 因为最近云小哥哥换了一份工作,新公司比较忙,所以一直没有更新新的博客.云小哥哥新的公司是做区块链的,最近在学习区块链相关的东西(也算是乘坐上了区块链这艘大船).本博客是记录我搭建ethereum ...

  6. 尚硅谷Docker---1-5、docker简介

    尚硅谷Docker---1-5.docker简介 一.总结 一句话总结: docker是环境打包:有点像windows镜像 docker的实质:缩小版.精细版.高度浓缩版的一个小型的linux系统 1 ...

  7. ARM非对齐访问和Alignment Fault

    1.指令对齐 A64指令必须word对齐.尝试在非对齐地址取值会触发PC alignment fault. 1.1.PC alignment checking PC(Program Counter)寄 ...

  8. oracle常用sql语句和函数

    --查询表的字段数 select count(*) from user_tab_columns where table_name = '表名'; --查询数据库用户密码的profile(一般为defa ...

  9. 简单三步同步你的 VSCode 用户配置

    https://www.cnblogs.com/knight-errant/p/10444777.html 设备重装,换设备,VSCode 又要重新配置了?不不不,简单三步,让你的 VSCode 配置 ...

  10. leetcode 884. 两句话中的不常见单词 (python)

    给定两个句子 A 和 B . (句子是一串由空格分隔的单词.每个单词仅由小写字母组成.) 如果一个单词在其中一个句子中只出现一次,在另一个句子中却没有出现,那么这个单词就是不常见的. 返回所有不常用单 ...