javascript:使用document.getElementById读取数据为空分析
2013-04-27 20:21
561 查看
今天写个网页,想在页面加载onLoad时,动态显示由后台其他程序传来的数据时,用document.getElementById获取控件对象总是为空。但是检查了这个id确实是存在的。在网上查阅一番后才知道了其中的原因。
1.下面是一个简单的例子,页面加载时显示一段信息
执行后,确实是“在页面加载前,输出了信息”。
2.下面的例子会出现document.getElementById为空的情况。
我的计划是:在页面加载时,在<body></body>的文本框中显示由后台处理来的数据,比如这里的字符串“hello, my friend!”。但是这里通过通过document.getElementById读取的是对象为空。
因为onLoad方法在页面<body></body>加载之前执行,此时id="mes"对应文本框的文本框,还没有加载进去。
3.解决办法
在加载Html网页时,会加载<html></html>中的所以数据。先加载<head>,再加载<body>。
所以我们可在</body>之后,在</html>之前写入javascript就好了。程序顺序执行,执行到相应的javascript调用就可以执行。不是用onLoad方法。
代码如下:
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>
相关文章推荐
- 在ASP.net中使用javascript的document.getElementById属性
- 在JavaScript中使用document.getElementById()获取对象失败的原因
- JavaScript中也使用$美元符号来代替document.getElementById
- javascript在html中的加载顺序------为什么window.alert(document.getElementById("time").innerTex)无法弹出对话框
- document.getElementById使用
- javascript里Dom问题之document.getElementById('xx').innerHTML
- 直接使用Id和使用document.getElementById()的比较
- javascript 如何正确使用getElementById,getElementsByName(), and getElementsByTagName()
- 【转】document.getElementById与getElementsByName的区别(JavaScript)
- javascript使用getElementById会抓到name的问题
- javascript代码在ie8里报错 document.getElementById(...) 为空或不是对象的解决方法 原创
- document.getElementById使用
- javascript 如何正确使用getElementById,getElementsByName(), and getElementsByTagName()
- javascript代码在ie8里报错 document.getElementById(...) 为空或不是对象的解决方法 原创
- document.getElementById()方法使用
- document.getElementById()方法使用
- 关于document.getElementById回去的是什么数据
- DOCUMENT.GETELEMENTBYID使用
- 使用母板页后javascript getelementbyid出错的解决方案