jQuery Ajax封装(附带加载提示和请求结果提示模版)
1、创建HTML文件(demo)
<!doctype html>
<html lang="en">
<head>
<meta charset="UTF-8" />
<title>jQuery Ajax</title>
<script type="text/javascript" src="jquery-3.2.0.min.js"></script>
<style type="text/css">
button{
border: none;
outline: none;
background: rgba(225,0,0,0.88);
padding: 5px 50px;
color: #EFEFEF;
font-size: 16px;
font-weight: bold;
border-radius: 0 8px 8px 8px;
letter-spacing: 5px;
}
</style>
</head>
<body>
<article class="demo">
<button type="button" id="jpost">Post</button>
<button type="button" id="jget">Get</button>
</article>
</body>
</html>
2、创建加载提示模版并添加CSS样式
//JavaScript部分
var load = { init:function(){ //请求开始 var article = document.createElement('article') article.className = 'loader' var div = document.createElement('div') div.className = 'loading' var tips = ['拼','命','加','载','中','···'] for(var index = 0;index<tips.length;index++){ var span = document.createElement('span') span.innerHTML = tips[index] div.appendChild(span) } article.appendChild(div) var body = document.getElementsByTagName('body')[0] body.appendChild(article) }, remove:function(){ //请求完成 var body = document.getElementsByTagName('body')[0] var loadText = document.getElementsByClassName('loader')[0] console.log(loadText) body.removeChild(loadText) } }
//CSS样式部分
.loader .loading span{ display: inline-block; position: relative; margin: 5px; } .loader .loading span:nth-child(even){ animation: moveup 2s linear infinite; } .loader .loading span:nth-child(odd){ animation: movedown 2s linear infinite; } @keyframes movedown{ 0%{bottom: 3px;} 50%{bottom:-3px;} 100%{bottom: 3px;} } @keyframes moveup{ 0%{top: 3px;} 50%{top:-3px;} 100%{top: 3px;} }
3、创建请求提示模版并添加CSS样式
//JavaScript部分
function tip(tipMsg,time){ tipMsg = tipMsg|| '请求异常,请联系客服!' //默认提示信息 time = time || 3000 //默认提示时间 var addTip = document.createElement('article') addTip.className = 'tip-msg' var addText = document.createElement('p') addText.innerHTML = tipMsg addTip.appendChild(addText) var body = document.getElementsByTagName('body')[0] body.appendChild(addTip) setTimeout(function(){ //移除提示 var removeTip = document.getElementsByClassName('tip-msg')[0] body.removeChild(removeTip) },time) }
//CSS样式部分
.tip-msg{ width: 100%; text-align: center; position: fixed; top: 30%; z-index:; } .tip-msg>p{ display: inline-block !important; background-color: rgba(0,0,0,0.8); color: #FFFFFF; padding: 2px 8px; border-radius: 5px; }
4、封装jQuery Ajax 方法
function baseAjax(requestPath, requestData,requestType,succCallback, errorCallback, dataType){
/*requestPath:请求路径
requestData:请求参数,默认为空
requestType:请求方式("POST" 或 "GET"), 默认为 "GET"
succCallback:请求成功回调函数
errorCallback:请求失败回调函数
dataType:预期服务器返回的数据类型, 默认为 JSON */
requestData = requestData || {}
requestType = requestType || 'GET'
dataType = dataType || 'JSON'
$.ajax({
url:requestPath, //请求地址
type:requestType, //请求类型
data:requestData, //请求数据
timeout:100000, //请求超时时间(毫秒)
beforeSend:function(){
load.init() //发送请求之前,插入加载提示信息“拼命加载中···”
},
success:function(res){ //请求成功
if(res.message == 'OK'){ //res.message不是唯一,也有可能是res.code 需结合项目实际场景来写入判断条件
if(succCallback){
succCallback(res) //返回OK回调函数,将返回的数据res传入到该回调函数中
}
}else{
if(errorCallback){
errorCallback(res) //返回不是OK时回调函数,将返回的数据res传入到该回调函数中
}
}
},
complete:function(res,status){
load.remove() //请求完成 移除加载提示“拼命加载中···”
},
error:function(){
tip() //请求错误,弹出提示
}
})
}
5、再次封装上面的jQuery Ajax 方法
function jPost(path,data,succCallback,errorCallback){
//再次封装-有参数
baseAjax(path,data,'POST',succCallback,errorCallback)
}
function noParameterJPost(path,succCallback,errorCallback){
//再次封装-无参数
baseAjax(path,{},'POST',succCallback,errorCallback)
}
function jGet(path,data,succCallback,errorCallback){
//再次封装-有参数
baseAjax(path,data,'GET',succCallback,errorCallback)
}
function noParameterJGet(path,succCallback,errorCallback){
//再次封装-无参数
baseAjax(path,{},'GET',succCallback,errorCallback)
}
//只写了这两种类型请求方法,其他方式依次类推
6、使用上面封装的 jPost() 和 jGet()方法演示两个请求
$("#jpost").on('click',function(){
jPost('http://api.36wu.com/Mobile/GetMobileOwnership',{
mobile:15988886666,
format:'json',
authkey:'5f5d61494c8d41de854f853978aefe696'
},function(res){
tip(res.status,1500) //请求成功,且 res.status == 'OK'
},function(res){
tip(res.status+' : '+res.message,1500)//请求成功,且 res.status != 'OK',弹出服务器返回的错误信息
})
})
$("#jget").on('click',function(){
jGet('http://api.36wu.com/Ip/GetIpInfo',{
ip:'192.168.1.106',
format:'json',
authkey:'5f5d61494c8d41de854f853978aefe69'
},function(res){
tip(res.status,1500) //请求成功,且 res.status == 'OK'
},function(res){
tip(res.status+' : '+res.message,1500) //请求成功,且 res.status != 'OK',弹出服务器返回的错误信息
})
})
说明:写的不好请不要建议,有任何疑问欢迎沟通交流 QQ:306344599
jQuery Ajax封装(附带加载提示和请求结果提示模版)的更多相关文章
- jQuery ajax瀑布流加载静态的列表页面
1.加载一行数据 <script> //滚动加载事件 var Loadurl = "{$url}"; if(window.location.href !== Loadu ...
- JQuery ajax 滚动底部加载更多
<%@ Page Language="C#" %> <%@ Import Namespace="System.IO" %> <%@ ...
- jquery+ajax无刷新加载数据,新闻浏览更多
<script type="text/javascript"> $(document).ready(function (){ $(window).scroll(fu ...
- [转]jquery的ajax交付时“加载中”提示的处理方法
本文转自:http://www.educity.cn/wenda/77121.html jquery的ajax提交时“加载中”提示的处理方法 方法1:使用ajaxStart方法定义一个全局的“加 ...
- jquery的ajax提交时“加载中”提示的处理方法
方法1:使用ajaxStart方法定义一个全局的“加载中...”提示 $(function(){ $("#loading").ajaxStart(function(){ ...
- jquery中ajax跨域加载
今天学习ajax跨域加载,先来一段代码,异步加载的链接是爱奇艺的开源,我直接拿来用作测试 <!DOCTYPE html> <html lang="en"> ...
- jquery的ajax提交时加载处理方法
1.定义全局的,就是所有的ajax的请求的加载都会出现相同的提示 $(function(){ //加载成功显示的状态 $("#showLoading").ajaxSuccess(f ...
- 【Jquery mobile】动态加载ListView 转
[Jquery mobile]动态加载ListView 分类: Jquery Mobile2011-12-01 09:04 13984人阅读 评论(1) 收藏 举报 jquerylistviewmob ...
- ajax请求原理及jquery $.ajax封装全解析
.ajax原理: Ajax的原理简单来说通过XmlHttpRequest对象来向服务器发异步请求,从服务器获得数据,然后用javascript来操作DOM而更新页面.这其中最关键的一步就是从服务器获得 ...
- CSS和JavaScript以及Ajax实现预加载图片的方法及优缺点分析
预加载图片是提高用户体验的一个很好方法.图片预先加载到浏览器中,访问者便可顺利地在你的网站上冲浪,并享受到极快的加载速度.这对图片画 廊及图片占据很大比例的网站来说十分有利,它保证了图片快速.无缝地发 ...
随机推荐
- Python 基础之基本数据类型
首先,Python中的变量不需要声明.每个变量在使用前都必须赋值,变量赋值以后该变量才会被创建.在Python中,变量就是变量,它没有类型,我们所说的"类型"是变量所指的内存中对象 ...
- JAVA内存模型5-锁
锁的释放-获取建立的happens before关系 锁是java并发编程中最重要的同步机制.锁除了让临界区互斥执行外,还可以让释放锁的线程向获取同一个锁的线程发送消息.下面是锁释放-获 ...
- System.load 与 System.loadLibrary 的使用
相同点 它们都可以用来装载库文件,不论是JNI库文件还是非JNI库文件. 在任何本地方法被调用之前必须先用这个两个方法之一把相应的JNI库文件装载. System.load System.load 参 ...
- Sqlla: 数据库操作从未如此简单
Sqlla 一套数据库的 ORM 微型库,提供简单高效的 API 来操作数据库. Sqlla 拥有极少的API,使用方式简单.让开发者不需要关心数据库操作的具体细节,只需专注SQL和业务逻辑.同时简单 ...
- 使用windows桌面ftp上传文件到linux服务器
首先在linux服务器上安装ftp [root@host2 test]#yum -y install ftp vsftpd [root@host2 test]#service vsftpd start ...
- 笔记本shift变粘贴,粘滞键设置已关闭
之前手贱吧,拿湿抹布擦了擦笔记本电脑的自带键盘,然后部分按键失灵了. 本想着反正也都是在寝室用的,趁机找借口买了个机械键盘,啪啪啪... 刚开始好好的,后来发现一按shift就会粘贴,百度了下都说是粘 ...
- Spring Boot 负载均衡之外置session状态保存
在使用spring boot做负载均衡的时候,多个app之间的session要保持一致,这样负载到不同的app时候,在一个app登录之后,而打到另外一台服务器的时候,session丢失. 常规的解决方 ...
- Android学习探索之App多渠道打包及动态添加修改资源属性
前言: 关于Android渠道打包是一个比较老的话题,今天主要记录总结一下多渠道打包以及如果动态配置修改一些资源属性.今天以公司实际需求为例进行演示,由于项目复用很多公共的业务组件,而且业务组件之间的 ...
- SQL写操作 设置内容 (数组转字符串)
SQL写操作 设置内容 (数组转字符串) SQL set内容 SQL操作数组转字符串 SQL写操作 set内容 (数组转字符串) [ 封装方法 ] function getSqlSet( $data ...
- mysqldump命令详解
1.数据备份的重要性: 保护公司的数据 网站的7x24提供服务 2.MySQL数据库备份: --all-databases , -A 导出全部数据库. mysqldump -uroot -p --al ...