欢迎访问 生活随笔!

生活随笔

当前位置: 首页 > 前端技术 > javascript >内容正文

javascript

javascript:使用document.getElementById读取数据为空分析

发布时间:2025/1/21 javascript 73 豆豆
生活随笔 收集整理的这篇文章主要介绍了 javascript:使用document.getElementById读取数据为空分析 小编觉得挺不错的,现在分享给大家,帮大家做个参考.

  今天写个网页,想在页面加载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>

 


 

 

 

 

总结

以上是生活随笔为你收集整理的javascript:使用document.getElementById读取数据为空分析的全部内容,希望文章能够帮你解决所遇到的问题。

如果觉得生活随笔网站内容还不错,欢迎将生活随笔推荐给好友。