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


Posted in Javascript onNovember 20, 2013

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 相关文章推荐
网页常用特效代码整理
Jun 23 Javascript
用dtree实现树形菜单 dtree使用说明
Oct 17 Javascript
使用JS实现jQuery的addClass, removeClass, hasClass函数功能
Oct 31 Javascript
浅谈JavaScript中的Math.atan()方法的使用
Jun 14 Javascript
详解AngularJS中自定义指令的使用
Jun 17 Javascript
JS+CSS实现仿雅虎另类滑动门切换效果
Oct 13 Javascript
微信小程序  自定义创建详细介绍
Oct 27 Javascript
手机移动端实现 jquery和HTML5 Canvas的幸运大奖盘特效
Dec 06 Javascript
JS 判断某变量是否为某数组中的一个值的3种方法(总结)
Jul 10 Javascript
[原创]js实现保存文本框内容为本地文件兼容IE,chrome,火狐浏览器
Feb 14 Javascript
使用vue-cli打包过程中的步骤以及问题的解决
May 08 Javascript
JS实现简单日历特效
Jan 03 Javascript
jquery html动态生成select标签出问题的解决方法
Nov 20 #Javascript
js数组转json并在后台对其解析具体实现
Nov 20 #Javascript
javascript 循环调用示例介绍
Nov 20 #Javascript
jquery实现可拖动DIV自定义保存到数据的实例
Nov 20 #Javascript
JavaScript实现多维数组的方法
Nov 20 #Javascript
jQuery jcrop插件截图使用方法
Nov 20 #Javascript
javascript中的if语句使用介绍
Nov 20 #Javascript
You might like
关于PHP结束标签的使用细节探讨及联想
2013/03/04 PHP
多个PHP中文字符串截取函数
2013/11/12 PHP
Zend Framework动作助手FlashMessenger用法详解
2016/03/05 PHP
php插入含有特殊符号数据的处理方法
2016/11/24 PHP
分享一个asp.net pager分页控件
2012/01/04 Javascript
基于jquery的网站幻灯片切换效果焦点图代码
2013/09/15 Javascript
jquery中load方法的用法及注意事项说明
2014/02/22 Javascript
浅析JS中document对象的一些重要属性
2014/03/06 Javascript
Window.Open如何在同一个标签页打开
2014/06/20 Javascript
javascript实现炫酷的拖动分页
2015/05/11 Javascript
JavaScript实现的Tween算法及缓冲特效实例代码
2015/11/03 Javascript
js实现微信分享代码
2020/10/11 Javascript
JS实现的图片预览插件与用法示例【不上传图片】
2016/11/25 Javascript
有关suggest快速删除后仍然出现下拉列表的bug问题
2016/12/02 Javascript
使用 NodeJS+Express 开发服务端的简单介绍
2017/04/07 NodeJs
angular json对象push到数组中的方法
2018/02/27 Javascript
微信小程序加载机制及运行机制图解
2019/11/27 Javascript
原生js实现购物车
2020/09/23 Javascript
JS+JQuery实现无缝连接轮播图
2020/12/30 jQuery
[04:26]DOTA2上海特锦赛小组赛第二日 TOP10精彩集锦
2016/02/27 DOTA
[01:01:01]完美世界DOTA2联赛循环赛 GXR vs FTD BO2第一场 10.29
2020/10/29 DOTA
详细解读tornado协程(coroutine)原理
2018/01/15 Python
详解关于Django中ORM数据库迁移的配置
2018/10/08 Python
python使用epoll实现服务端的方法
2018/10/16 Python
Python解决线性代数问题之矩阵的初等变换方法
2018/12/12 Python
Python实现去除列表中重复元素的方法总结【7种方法】
2019/02/16 Python
基于PyQt4和PySide实现输入对话框效果
2019/02/27 Python
用Python识别人脸,人种等各种信息
2019/07/15 Python
python3 实现函数写文件路径的正确方法
2019/11/27 Python
python实现模拟器爬取抖音评论数据的示例代码
2021/01/06 Python
python实现录制全屏和选择区域录屏功能
2021/02/05 Python
联想法国官方网站:Lenovo法国
2018/10/18 全球购物
校园文化艺术节宣传标语
2014/10/09 职场文书
计划生育汇报材料
2014/12/26 职场文书
幼儿园教师暑期培训心得体会
2016/01/09 职场文书
2016年推广普通话宣传周活动总结
2016/04/06 职场文书