JavaScript Document.Write 在使用 AJAX 时替换所有正文内容

IT技术 javascript ajax
2021-01-29 17:44:27

我正在创建一个简单的 ajax 调用,它检索指定 url 的内容并将其写入页面。我遇到的问题是它用此信息替换了整个正文内容

这是JS:

(function(){
    var mb = window.mb = {};

    function get_ad(url, parameters){
        var result = "";
        var http_request = false;

        if (window.XMLHttpRequest) { // Mozilla, Safari,...
            http_request = new XMLHttpRequest();
            if (http_request.overrideMimeType) {
                http_request.overrideMimeType('text/html');
            }
        } else if (window.ActiveXObject) { // IE
            var avers = ["Microsoft.XmlHttp", "MSXML2.XmlHttp", "MSXML2.XmlHttp.3.0", "MSXML2.XmlHttp.4.0", "MSXML2.XmlHttp.5.0"];
            for (var i = avers.length -1; i >= 0; i--) {
                try {
                    http_request = new ActiveXObject(avers[i]);
                    if (http_request){
                        break;  
                    }
                } catch(e) {}
            }
        }
        if (!http_request) {
            alert('Cannot create XMLHTTP instance');
            return false;
        }

        http_request.onreadystatechange = function(){
                                              if (http_request.readyState == 4) {
                                                 if (http_request.status == 200) {
                                                    gen_output(http_request.responseText);
                                                 } else {
                                                    alert('Error');
                                                 }
                                              }
                                           }

        http_request.open('GET', url + parameters, true);
        http_request.send(null);
    }

    function gen_output(ad_content){
        document.write("<div id=\"mb_ad\">");
        document.write(ad_content);
        document.write("</div>");
    }

    get_ad("http://localhost/test/test.html", "");
})();

这是html:

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Untitled Document</title>
</head>

<body>
    i am text before <br/>
    <script type="text/javascript" src="mb.js"></script>
    <br />
    i am text after 
</body>
</html>

使用 firebug 进行检查,我看不到之前或之后的文本,只有<div id="mb_ad">test.html 页面中和 内容。如果我删除 ajax 调用并只执行 3document.writes之前的文本和之后的文本将正确显示。jQuery 不是一种选择,我必须在没有大型库帮助的情况下执行此操作,因为大小和速度至关重要。

6个回答

document.write一旦文档完成加载,您将无法使用如果这样做,浏览器将打开一个新文档来替换当前文档。

使用该innerHTML属性将 HTML 代码放入元素中:

function gen_output(ad_content){
  document.getElementById('mb_ad').innerHTML = ad_content;
}

将元素放在脚本之前,以便在调用回调函数时确定它存在:

i am text before
<div id="mb_ad"></div>
i am text after
<script type="text/javascript" src="mb.js"></script>

放置脚本的位置无关紧要,因为不会将任何内容写入文档所在的位置。

有没有可能在没有单独的情况下完成我正在尝试的事情div这应该是嵌入到客户站点中的内容,我被要求通过单个脚本调用来完成。
2021-03-16 17:44:27
是的,您可以在进行 AJAX 调用之前使用 document.write 将 div 写入页面。
2021-03-24 17:44:27

如果您无法控制远程脚本,您可以编写如下内容:

<script>
var tmp = document.write;

document.write = function () {
  document.getElementById('someId').innerHTML = [].concat.apply([], arguments).join('');
};
</script>
<script .....>
document.write = tmp;

嗯,这是一个讨厌的黑客,但它似乎有效......

var div = document.createElement('div');
div.id = 'mb_ad';
div.innerHTML = ad_content;

现在,您可以将此节点附加到任何您想要的位置。

您可以使用 <script>document.body.innerHTML+="//Your HTML Code Here";</script>

相同的 Leon Fedotov 回答但更多 jQuery

{
  var old_write = document.write;

  var $zone = $('.zone.zone_' + name);
  // redefine document.write in this closure
  document.write = function () {
    $zone.append([].concat.apply([], arguments).join(''));
  };
  // OA_output[name] contains dangerous document.write
  $zone.html(OA_output[name]);

  document.write = old_write;
}