1

我正在处理分页或过滤器更改时产品表内容的异步加载(使用 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功能上,但不知道如何对其进行测试以定义确切的问题。

4

1 回答 1

1

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

于 2015-11-27T10:00:33.923 回答