本文所分享的知识点是【document.getElementById获取控件对象为空的解决方法】,欢迎您喜欢我爱IT技术网所分享的教程、知识、经验或攻略,下面是详细的讲解。
document.getElementById获取控件对象为空的解决方法
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>
关于document.getElementById获取控件对象为空的解决方法的相关讨论如下:
相关问题:asp.net document.getElementById 为什么获取不到...
答:怎么会呢?除非,你有俩个相同ID的控件。 >>详细
相关问题:asp.netButton事件中调用js问题:document.getElem...
答:因为button有runat=server,所以要取的客户端的id, document.getElementById("").value >>详细
相关问题:asp.net Button事件中调用js问题:document.getEle...
答:1楼已经说明了为什么事null 因为JS 代码 在 Html 代码前面,所以Html 代码没有加载完成就 来一个 getElementById 肯定为 null 对象。 具体的解决方法,Page.ClientScript.RegisterStartupScript(Page.GetType(), "message", " alert('删除成功')... >>详细
- 评论列表(网友评论仅供网友表达个人看法,并不表明本站同意其观点或证实其描述)
-
