XmlHttpResponse 向服务器发送请求

29 篇文章 0 订阅

  使用XMLHttpRequest 向服务器端发送请求,其中具体的js如下:

        var request = null;
        var queryString; // 将保存 posted 的数据
  
        /* 构建 Request 对象的封装函数
        参数:
        reqType: http 请求类型, post 或 get
        url: 服务器端程序的url
        asynch: 是否异步发送请求
        respHandle: 处理响应的函数名

        */
        function httpRequest(reqType, url, asynch, respHandle) {
            // 基于 MOzilla 的浏览器
            if (window.XMLHttpRequest) {
                request = new XMLHttpRequest();
            } else if(window.ActiveXObject) {
                request = new ActiveXObject("Msxm12.XMLHTTP");
                if (!request) {
                    request = new ActiveXObject("Microsoft.XMLHTTP");
                }
            }

            //检测 request 是否为null
            //  如果 ActiveXObject 还没有初始化
            if (request) {
                // 如果 reqType 参数是post, 那么函数的第五个参数是 posted 的数据
                if (reqType.toLowerCase != "post") {
                    initReq(reqType, url, asynch, respHandle);
                } else {
                    //posted 数据
                    var args = arguments[4];
                    if (args == null && args.length > 0) {
                        initReq(reqType, url, asynch, respHandle, args);
                    }
                }

            } else {
                alert("Your brower does not permit the use of all  of this application's features!");
            }
        }


        function initReq(reqType, url, bool, respHandle) {

            try {
                // 指定处理http响应的函数
                request.onreadystatechange=respHandle;
                request.open(reqType,url,bool);
                // 如果 reqType 参数是post, 那么函数的第五个参数是 posted 的数据
                if (reqType.toLowerCase == "post") {
                    request.setRequestHaader("Content-Type","application/x-www-form-urlencoded;charset-UTF-8");
                    request.send(arguments[4]);
                }
            } catch (error) {
                alert("The application cannot contact the server at the moment");
            }
        }

        //处理请求
        function handleResponse() {
            // 完成响应
            if (request.readyState == 4) {
                // OK
                if (request.status == 200) {

                    alert(request.responseText);
                }
                    
            }
        }


 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值