开发者问题收集

使用 XMLHttpRequest 在容器中创建容器

2020-04-15
129

我想使用 AJAX 在 div 容器中创建一个 div 容器,然后在内部容器中写入“Hello World”。外部容器没有特殊功能。它只是容纳内部容器。这是我的代码:

inex.html:

<!DOCTYPE html>
<html>

    <head><meta charset="UTF-8"></head>

    <body>

        <div id="outerContainer"></div>        // this is my outer container

        <script>
            function request(){
                var req = new XMLHttpRequest();
                req.open("get", "response.php", true);
                req.onreadystatechange=function(){
                    if(this.readyState == 4 && this.status == 200)
                        document.getElementById('outerContainer').innerHTML = this.responseText; 
                };
                req.send();
            }            
            request();

            // write "Hello World" in the inner container
            document.getElementById('innerContainer').innerHTML = "Hello World";
        </script>

    </body>

</html>

response.php

<?php
echo "<div id='innerContainer'>default text</div>";      // put this container inside the outer container
?>

运行程序后,我可以在 DOM 中看到内部 div 容器在外部 div 容器内正确创建,并且它的 ID 是“innerContainer”。但是,我尝试在内部容器中写入“Hello World”却不起作用。相反,它的内容仍然是“默认文本”。控制台输出:“index.html:21 Uncaught TypeError: 无法设置 null 的属性‘innerHTML’”。

我将非常感激任何建议或帮助。

2个回答

我尝试了我在评论中所说的方法,并且成功了。

当您在代码中运行 document.getElementById('innerContainer').innerHTML = "Hello World"; 时,此元素可能不存在(因此出现“null”错误)。您必须记住,您正在发出异步请求。因此,代码的其他部分将在发出请求时执行。

一种解决方案是将“hello text”移到响应内。因此,这种方法有效:

<!DOCTYPE html>
<html>

    <head><meta charset="UTF-8"></head>

    <body>

        <div id="outerContainer"></div>

        <script>
            function request(){
                var req = new XMLHttpRequest();
                req.open("get", "random.php", true);
                req.onreadystatechange=function(){
                    if(this.readyState == 4 && this.status == 200)
                        document.getElementById('outerContainer').innerHTML = this.responseText;

                        document.getElementById('innerContainer').innerHTML = "Hello World";
                };
                req.send();
            }
            request();

        </script>

    </body>

</html>

如您所见,只有在元素实际存在后才会插入 Hello World。那么就不会出现不存在的 div。

code noob
2020-04-15

529046199

Shubham
2020-04-15