ajax的get和post请求工具类:

/**
 * 公共方法类
 *
 * 使用  变量名=function()定义函数时,如果在变量名前加var,则这个变量变成局部变量
 */
var Common = function() {
    
    /*
     * 获取url参数
     */
    var getQueryStr = function(sUrlParam, sArgName) {
        var retval = "";
        if (sUrlParam == null || sUrlParam.length == 0) {
            return retval;
        }
        var args = sUrlParam.split("&");
        for (var i = 0; i < args.length; i++) {
            sUrlParam = args[i];
            var arg = sUrlParam.split("=");
            if (arg.length <= 1)
                continue;
            if (arg[0] == sArgName)
                retval = arg[1];
        }
        return retval;
    }
    
    /*
     * ajax发送post请求
     */
    var postReq = function(url, param, fnCallback, isIndex) {
        var target, options = {
            title : "异常信息",
            content : "",
            bodyType : "errorMessage"
        };
        
        if (isIndex) {
            target = window;
        }
        else {
            target = window.parent;
        }
        
       $.ajax({
                url : url,
                type : "POST",
                timeout : 300000,
                headers:"Access-Control-Allow-Origin:*",
                contentType : "application/x-www-form-urlencoded;charset=UTF-8",
                dataType : "json",
                data : param
            }).done(function(data, textStatus, jqXHR) {
                if (jqXHR.getResponseHeader('sessionStatus') == 'timeout') {
                    options.content = '会话已经超时.';
                    target.showModal(options, function() {
                            target.location.href = 'login.html';
                        });
                }
                else if (!data) {
                    options.content = '无返回信息.';
                    target.showModal(options, function() {
                            // donothing
                        });
                }
                else {
                    fnCallback(data);
                }
            }).fail(function(jqXHR, textStatus, errorThrown) {
                if (jqXHR.status == 0) {
                    options.content = '请求异常,网络连接失败!';
                }
                else if (jqXHR.status == 403) {
                    options.content = jqXHR.responseJSON.message;
                }
                else {
                    options.content = "请求异常,状态码:" + jqXHR.status;
                }
                
                target.showModal(options, function() {
                        // donothing
                    });
            });
    };
    
    var postReq = function(url, param, fnCallback, isIndex) {
        var target, options = {
            title : "异常信息",
            content : "",
            bodyType : "errorMessage"
        };
        
        if (isIndex) {
            target = window;
        }
        else {
            target = window.parent;
        }
        
       $.ajax({
                url : url,
                type : "POST",
                timeout : 300000,
                contentType : "application/x-www-form-urlencoded;charset=UTF-8",
                dataType : "json",
                data : param
            }).done(function(data, textStatus, jqXHR) {
                if (jqXHR.getResponseHeader('sessionStatus') == 'timeout') {
                    options.content = '会话已经超时.';
                    target.showModal(options, function() {
                            target.location.href = 'login.html';
                        });
                }
                else if (!data) {
                    options.content = '无返回信息.';
                    target.showModal(options, function() {
                            // donothing
                        });
                }
                else {
                    fnCallback(data);
                }
            }).fail(function(jqXHR, textStatus, errorThrown) {
                if (jqXHR.status == 0) {
                    options.content = '请求异常,网络连接失败!';
                }
                else if (jqXHR.status == 403) {
                    options.content = jqXHR.responseJSON.message;
                }
                else {
                    options.content = "请求异常,状态码:" + jqXHR.status;
                }
                
                target.showModal(options, function() {
                        // donothing
                    });
            });
    };
    
    return {
        getQueryStr : getQueryStr,
        postReq : postReq
    }
}();

调用方法:

Common.postReq('svcinfo/findForSelect.do', {
                            svcAlias : key
                        }, function(json) {
                            if ($.trim(key) == '') {
                                // splice(a1,a2,a3...)从a1位置开始替换a2个元素为a3...
                                json.data.splice(0, 0, {
                                        svnName : 'all',
                                        svcAlias : '所有服务'
                                    });
                            }
                            me.cacheDataSource = [];//清空原数组,避免内存泄露
                            me.cacheDataSource[key] = json.data;
                            query.callback({
                                    results : json.data
                                });
                        });

ajax请求工具类的更多相关文章

  1. 微信https请求工具类

    工作中用到的微信https请求工具类. package com.gxgrh.wechat.tools; import com.gxgrh.wechat.wechatapi.service.System ...

  2. WebUtils-网络请求工具类

    网络请求工具类,大幅代码借鉴aplipay. using System; using System.Collections.Generic; using System.IO; using System ...

  3. Http、Https请求工具类

    最近在做微信开发,使用http调用第三方服务API,有些是需要https协议,通过资料和自己编码,写了个支持http和https的工具类,经验证可用,现贴出来保留,也供需要的人使用(有不足的地方,也请 ...

  4. HTTP请求工具类

    HTTP请求工具类,适用于微信服务器请求,可以自测 代码; /// <summary> /// HTTP请求工具类 /// </summary> public class Ht ...

  5. 实现一个简单的http请求工具类

    OC自带的http请求用起来不直观,asihttprequest库又太大了,依赖也多,下面实现一个简单的http请求工具类 四个文件源码大致如下,还有优化空间 MYHttpRequest.h(类定义, ...

  6. 远程Get,Post请求工具类

    1.远程请求工具类   import java.io.*; import java.net.URL; import java.net.URLConnection; import java.util.L ...

  7. C#实现的UDP收发请求工具类实例

    本文实例讲述了C#实现的UDP收发请求工具类.分享给大家供大家参考,具体如下: 初始化: ListeningPort = int.Parse(ConfigurationManager.AppSetti ...

  8. 【原创】标准HTTP请求工具类

    以下是个人在项目开发过程中,总结的Http请求工具类,主要包括四种: 1.处理http POST请求[XML格式.无解压]: 2.处理http GET请求[XML格式.无解压]: 3.处理http P ...

  9. 我的Android进阶之旅------>Android关于HttpsURLConnection一个忽略Https证书是否正确的Https请求工具类

    下面是一个Android HttpsURLConnection忽略Https证书是否正确的Https请求工具类,不需要验证服务器端证书是否正确,也不需要验证服务器证书中的域名是否有效. (PS:建议下 ...

随机推荐

  1. Thread 1 cannot allocate new log的问题分析 (转载)

    Thread 1 cannot allocate new log的问题分析 发生oracle宕机事故,alert文件中报告如下错误: Fri Jan 12 04:07:49 2007Thread 1 ...

  2. python3 string

    字符串是 Python 中最常用的数据类型.我们可以使用引号('或")来创建字符串. 创建字符串很简单,只要为变量分配一个值即可.例如: var1 = 'Hello World!' var2 ...

  3. Spring AOP课程实战

  4. cplexJava源码---计算结果

    public static class CplexStatus implements Serializable { static final long serialVersionUID = -7367 ...

  5. ckeditor源码编辑模式,添加style、javascript内容丢失的解决

    我使用ckeditor 我在编辑的使用源码编辑,保存内容包含javascript.style标签的时候,数据库中有javascript.style标签 , 输入到页面也可以执行,但是我再次编辑的时候就 ...

  6. scala.XML处理

    XML scala提供了对xml字面量的内建支持,我们可以很容易的在程序代码中生成xml片段, scala类库也包含了对xml常用处理的支持 有时候scala会错误识别出xml字面量 如x < ...

  7. CSS镂空图片处理

    来源:http://www.zhangxinxu.com/wordpress/?p=5267,分享收藏 使用镂空图片,通过CSS改变颜色,达到图片切换的效果,可以同过背景图,然后改变背景色,从而达到图 ...

  8. as2 loadClip

    loadClip(url:String, target:Object) : Boolean target是直接被赋值,而不是add进去

  9. JUC学习记录

    先附上学习的博客地址:http://blog.csdn.net/cx8122389/article/details/70049425, 具体见该博客 Java JUC 简介 在Java 5.0 提供了 ...

  10. c:forEach varStatus属性

    转自:https://blog.csdn.net/jzy23682891/article/details/7075904 c:forEach varStatus属性 current当前这次迭代的(集合 ...