document.getElementById获取控件对象为空的解决方法_Javascript教程-查字典教程网
document.getElementById获取控件对象为空的解决方法
document.getElementById获取控件对象为空的解决方法
发布时间:2016-12-30 来源:查字典编辑
摘要:1.下面是一个简单的例子,页面加载时显示一段信息复制代码代码如下:alert("hello!!!");在页面加载之前,会输出一些信息执行后,...

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>

<>

<script language="javascript">

function showMessage()

{

var t=document.getElementById("mes");

t.value="hello, my friend!"

}

showMessage(); //调用方法,更新文本框

</script>

</html>

相关阅读
推荐文章
猜你喜欢
附近的人在看
推荐阅读
拓展阅读
  • 大家都在看
  • 小编推荐
  • 猜你喜欢
  • 最新Javascript教程学习
    热门Javascript教程学习
    编程开发子分类