document.getElementById获取控件对象为空的解决方法

转载 2013年12月03日 14:25:09

今天写个网页,想在页面加载onLoad时,动态显示由后台其他程序传来的数据时,用document.getElementById获取控件对象总是为空。但是检查了这个id确实是存在的。

看下文的示例和解决方法

1.下面是一个简单的例子,页面加载时显示一段信息
代码如下:
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
      <script language="javascript">
          alert("hello!!!");
      </script>
  </head>

  <body onLoad="showMessage()">
      <h1>在页面加载之前,会输出一些信息</h1>
  </body>
</html>
执行后,确实是“在页面加载前,输出了信息”。
2.下面的例子会出现document.getElementById为空的情况。
我的计划是:在页面加载时,在<body></body>的文本框中显示由后台处理来的数据,比如这里的字符串“hello, my friend!”。但是这里通过通过document.getElementById读取的是对象为空。
因为onLoad方法在页面<body></body>加载之前执行,此时id="mes"对应文本框的文本框,还没有加载进去。
代码如下:
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
  <head>
      <script language="javascript">
          var t=document.getElementById("mes");
          t.value="hello, my friend!"
      </script>
  </head>

  <body onLoad="showMessage()">
      the message is:<input type="text" id="mes">
  </body>
</html>
3.解决办法
在加载Html网页时,会加载<html></html>中的所以数据。先加载<head>,再加载<body>。
所以我们可在</body>之后,在</html>之前写入javascript就好了。程序顺序执行,执行到相应的javascript调用就可以执行。不是用onLoad方法。
代码如下:
<%@ page language="java" import="java.util.*" pageEncoding="UTF-8"%>
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html>
    <body>
          the message is:<input type="text" id="mes">
    </body>

      <!-- 继续执行javascript代码 -->
    <script language="javascript">
          function showMessage()
          {
              var t=document.getElementById("mes");
              t.value="hello, my friend!"
          }
          showMessage();    //调用方法,更新文本框
      </script>
</html>

Document对象的使用:getElementById()和getElementsByTagName()方法的使用练习

Document对象的使用:getElementById()和getElementsByTagName()方法的使用练习 1、  查找并访问节点 你可以通过若干方法来查找您希望操作的元素: (1...

在JavaScript中使用document.getElementById()获取对象失败的原因

在JavaScript中使用以下方法 document.getElementById()getElementsByName()getElementsByTagName() 等等类似方法获取元素对...

javascript中document.getelementbyid缺少对象的问题原因

function show(){ var mymario=document.getElementById('mymario');  window.alert(mymario.style.top);...
  • w15454
  • w15454
  • 2014年05月10日 12:20
  • 529

藏在IE中的Bug:关于document.getElementById()方法

Document类型提供了两个方法:document.getElementById()和getElementsByTagName()来取得特定的某个或某组元素的引用。        getEleme...

document.getElementById()方法使用

document.getElementById使用 语法:oElement = document .getElementById ( sID ) 参数:sID――必选项。字符串 (String) ...
  • pyffcwj
  • pyffcwj
  • 2012年02月07日 17:51
  • 236112

RequiredFieldValidator控件验证不能为空时报错多种解决方法以及问题分析

RequiredFieldValidator控件验证不能为空时报错多种解决方法以及问题分析
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:document.getElementById获取控件对象为空的解决方法
举报原因:
原因补充:

(最多只允许输入30个字)