AJAX无法在另一页

时间:2017-08-31 20:01:24

标签: javascript ajax

为什么AJAX无法使用JavaScript加载另一个HTML页面?它加载HTML,CSS,PHP等......但不是JavaScript。 AJAX应该像那样工作吗?如果是这样,我如何加载包含JS和AJAX的另一个HTML页面?

我的意思是一个简单的例子

a.php只会

<!DOCTYPE html>
<html>
<body>

<div id="demo">
<h1>The XMLHttpRequest Object</h1>
<button type="button" onclick="loadDoc()">Change Content</button>
</div>

<script>
function loadDoc() {
  var xhttp = new XMLHttpRequest();
  xhttp.onreadystatechange = function() {
    if (this.readyState == 4 && this.status == 200) {
      document.getElementById("demo").innerHTML =
      this.responseText;
    }
  };
  xhttp.open("GET", "b.php", true);
  xhttp.send();
}
</script>

</body>
</html>

b.php

<!DOCTYPE html>
<html>
<body>
<h1>b</h1>
<script>
document.write("Hello World!");
</script>

</body>
</html>

回复截图:
AJAX response screen shot

1 个答案:

答案 0 :(得分:0)

因为您通过ajax获取的javascript代码是一个简单的字符串而不会被执行。您必须eval()脚本标记中的代码,如:

示例:

<script id="helloworld">
document.write("Hello World!");
</script>

JS:

var jsCode = document.getElementById('helloworld').textContent;
eval(jsCode);

按要求编辑:

if (this.readyState == 4 && this.status == 200) {
    var demoElement = document.getElementById("demo");
    demoElement.innerHTML = this.responseText;
    var scriptTags = demoElement.getElementsByTagName('script');

    for(i = 0; i < scriptTags.length; i++) {
        eval(scriptTag[i].textContent);
    }
}