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+'&nbsp;:&nbsp;'+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+'&nbsp;:&nbsp;'+res.message,1500) //请求成功,且 res.status != 'OK',弹出服务器返回的错误信息
                    })
                })

说明:写的不好请不要建议,有任何疑问欢迎沟通交流 QQ:306344599

jQuery Ajax封装(附带加载提示和请求结果提示模版)的更多相关文章

  1. jQuery ajax瀑布流加载静态的列表页面

    1.加载一行数据 <script> //滚动加载事件 var Loadurl = "{$url}"; if(window.location.href !== Loadu ...

  2. JQuery ajax 滚动底部加载更多

    <%@ Page Language="C#" %> <%@ Import Namespace="System.IO" %> <%@ ...

  3. jquery+ajax无刷新加载数据,新闻浏览更多

      <script type="text/javascript"> $(document).ready(function (){ $(window).scroll(fu ...

  4. [转]jquery的ajax交付时“加载中”提示的处理方法

    本文转自:http://www.educity.cn/wenda/77121.html jquery的ajax提交时“加载中”提示的处理方法    方法1:使用ajaxStart方法定义一个全局的“加 ...

  5. jquery的ajax提交时“加载中”提示的处理方法

    方法1:使用ajaxStart方法定义一个全局的“加载中...”提示 $(function(){    $("#loading").ajaxStart(function(){    ...

  6. jquery中ajax跨域加载

    今天学习ajax跨域加载,先来一段代码,异步加载的链接是爱奇艺的开源,我直接拿来用作测试 <!DOCTYPE html> <html lang="en"> ...

  7. jquery的ajax提交时加载处理方法

    1.定义全局的,就是所有的ajax的请求的加载都会出现相同的提示 $(function(){ //加载成功显示的状态 $("#showLoading").ajaxSuccess(f ...

  8. 【Jquery mobile】动态加载ListView 转

    [Jquery mobile]动态加载ListView 分类: Jquery Mobile2011-12-01 09:04 13984人阅读 评论(1) 收藏 举报 jquerylistviewmob ...

  9. ajax请求原理及jquery $.ajax封装全解析

    .ajax原理: Ajax的原理简单来说通过XmlHttpRequest对象来向服务器发异步请求,从服务器获得数据,然后用javascript来操作DOM而更新页面.这其中最关键的一步就是从服务器获得 ...

  10. CSS和JavaScript以及Ajax实现预加载图片的方法及优缺点分析

    预加载图片是提高用户体验的一个很好方法.图片预先加载到浏览器中,访问者便可顺利地在你的网站上冲浪,并享受到极快的加载速度.这对图片画 廊及图片占据很大比例的网站来说十分有利,它保证了图片快速.无缝地发 ...

随机推荐

  1. vue组件(将页面公用的头部组件化)

    呃……重新捡起前面用vue-cli快速生成的项目. 之前是做过一个多页面的改造,以及引入vux的ui组件,这次在这个项目的基础上,再来聊聊vue中的component. 别问我为啥总是写关于vue的博 ...

  2. 四、I/O

    九.什么是I/O: 9.1.在Windows程序中,基础的运行单位为线程,为每一个线程分配一个处理器,可以让系统执行多个操作, 9.2.当线程进行一个I/O操作时,会被挂起,从而影响性能,为了解决这类 ...

  3. 使用java API操作hdfs--读取hdfs文件并打印

    在myclass之中创建类文件,这个myclass目录是自己创建的. 编译的时候会报如下的错误: 很明显就是没有导入包的结果 见这个API网站,则可以找到响应的包,当然还有java的api文档 htt ...

  4. JAVA内存模型与线程

    概述 由于计算机的运算速度和它的存储和通讯子系统的速度差距巨大,大部分时间都花在IO,网络和数据库上.为了压榨CPU的运算能力,需要并发.另外,优秀的并发程序对于提高服务器的TPS有重要的意义. 硬件 ...

  5. hive、impala集成ldap

    1.概要 1.1 环境信息 hadoop:cdh5.10 os:centos6.7 user:root hive.impala已集成sentry 1.2 访问控制权限 这里通过使用openldap来控 ...

  6. php的八大数据类型

    1. 八大数据: bool 布尔类型:0,1:真假 integer 整形 float 浮点型 string 字符串 array 数组 object 对象,类,class resource 文件,图片, ...

  7. Linux 常 用 命 令

    一:关机命令 1:shutdown 语 法:shutdown [-efFhknr][-t 秒数][时间][警告信息] 说明:shutdown指令可以关闭所有程序,并依用户的需要,进行重新开机或关机的动 ...

  8. 测试class

    各种断言方法: assertEqual(a,b) a == b assertNotEqual(a,b) a != b assertTrue(x) x == True assertFalse(x) x ...

  9. linux不需要密码ssh登陆

    1. 自动ssh/scp方法A为本地主机(即用于控制其他主机的机器) ;B为远程主机(即被控制的机器Server), 假如ip为192.168.60.110;A和B的系统都是Linux在A上运行命令: ...

  10. zabbix监控redis

    导入监控模板 点击[configuration]-->[templates]-->[import],导入xml监控模板. 配置客户端key 在被监控的主机上,新建/etc/zabbix/z ...