源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

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

  • 时间:2022-06-22 09:55 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:document.getElementById获取控件对象为空的解决方法
1.下面是一个简单的例子,页面加载时显示一段信息
[u]复制代码[/u] 代码如下:
<%@ 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"对应文本框的文本框,还没有加载进去。
[u]复制代码[/u] 代码如下:
<%@ 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方法。 代码如下:
[u]复制代码[/u] 代码如下:
<%@ 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>
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部