28
<html>
<head>
    <title>Test javascript</title>

    <script type="text/javascript">
        var e = document.getElementById("db_info");
        e.innerHTML='Found you';
    </script>
</head>
<body>
    <div id="content">
        <div id="tables">

        </div>        
        <div id="db_info">
        </div>
    </div>
</body>
</html>

如果我使用alert(e);它会出现null......显然我没有在屏幕上看到任何“找到你”。我究竟做错了什么?

4

5 回答 5

78

问题是您试图在元素存在之前访问它。您需要等待页面完全加载。一种可能的方法是使用onload处理程序:

window.onload = function () {
    var e = document.getElementById("db_info");
    e.innerHTML='Found you';
};

不过,大多数常见的 JavaScript 库都提供了 DOM-ready 事件。这更好,因为window.onload也等待所有图像。在大多数情况下,您不需要它。

另一种方法是将脚本标签放在关闭</body>标签之前,因为它前面的所有内容都是在执行时加载的。

于 2010-12-21T10:55:02.660 回答
3

浏览器如何知道何时运行脚本标签内的代码?所以,要让代码在窗口完全加载后运行,

window.onload = doStuff;

function doStuff() {
    var e = document.getElementById("db_info");
    e.innerHTML='Found you';
}

另一种选择是将您的标签保留<script...</script>在结束</body>标签之前。

于 2010-12-21T10:56:33.223 回答
1

该脚本在构建主体的 DOM 之前执行。将其全部放入一个函数并从onloadbody-element 调用它。

于 2010-12-21T10:54:45.487 回答
1

在 onload 事件中运行代码,或者在关闭body标签之前运行代码。您尝试找到一个在您执行此操作时不存在的元素。

于 2010-12-21T10:55:05.397 回答
1

在元素存在之前调用脚本。

您应该尝试以下方法之一:

  1. 将代码包装到一个函数中并使用主体 onload 事件来调用它。
  2. 将脚本放在文档末尾
  3. 在脚本标签声明中使用 defer 属性
于 2010-12-21T10:58:01.400 回答