加载~400(错误请求)。 XmlHttpRequest适用于本地,但不适用于服务器端

时间:2015-11-27 08:42:08

标签: javascript jquery xmlhttprequest activexobject readystate

我正在处理关于分页或过滤器更改的产品表内容的异步加载(使用XMLHttpRequest .readystate& .responseText)。我编写的功能完美无缺,但仅限于本地。在apache / ngnix服务器端,它返回错误的请求。请帮忙。

function loadContent(link) {

    var http = createRequestObject();
    if( http ) {

        http.open('load', link);
        http.onreadystatechange = function () {

            if(http.readyState == 4) {

                var div = document.createElement('div');
                div.innerHTML = http.responseText;
                var all = div.getElementsByTagName('div');

                for (var i = 0, len = all.length; i < len; i++) {

                   if (all[i] && all[i].getAttribute('id') == 'to-ajax') {

                      var deep = all[i].getElementsByClassName('product-layout col-lg-4');
                      $('.load').before(deep);

                   }
                }
            }
        }

        http.send(null);

    } else {

        document.location = link;

    }
}

function createRequestObject() {
    try { return new XMLHttpRequest() }
    catch(e) {
        try { return new ActiveXObject('Msxml2.XMLHTTP') }
        catch(e) {

            try { return new ActiveXObject('Microsoft.XMLHTTP') }
            catch(e) { return null; }
        }
    }
}

错误警告引用此行代码~ } http.send(null);

似乎问题出现在.onreadystatechange函数上,但不知道如何测试它以定义确切的问题。

1 个答案:

答案 0 :(得分:1)

open的第一个参数需要是包含HTTP请求方法的字符串。 "load"不是HTTP请求方法。示例包括"GET""POST"。无效的HTTP可能导致服务器响应错误请求错误。