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>
執(zhí)行后,確實是“在頁面加載前,輸出了信息”。
2.下面的例子會出現(xiàn)document.getElementById為空的情況。
我的計劃是:在頁面加載時,在<body></body>的文本框中顯示由后臺處理來的數(shù)據(jù),比如這里的字符串“hello, my friend!”。但是這里通過通過document.getElementById讀取的是對象為空。
因為onLoad方法在頁面<body></body>加載之前執(zhí)行,此時id="mes"對應(yīng)文本框的文本框,還沒有加載進去。
<%@ 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網(wǎng)頁時,會加載<html></html>中的所以數(shù)據(jù)。先加載<head>,再加載<body>。
所以我們可在</body>之后,在</html>之前寫入javascript就好了。程序順序執(zhí)行,執(zhí)行到相應(yīng)的javascript調(diào)用就可以執(zhí)行。不是用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>
<!-- 繼續(xù)執(zhí)行javascript代碼 -->
<script language="javascript">
function showMessage()
{
var t=document.getElementById("mes");
t.value="hello, my friend!"
}
showMessage(); //調(diào)用方法,更新文本框
</script>
</html>
- js中document.getElementByid、document.all和document.layers區(qū)分介紹
- document.getElementById介紹
- jquery中的 $("#jb51")與document.getElementById("jb51") 的區(qū)別
- document.getElementById的簡寫方式(獲取id對象的簡略寫法)
- document.getElementById方法在Firefox與IE中的區(qū)別
- document.getElementById為空或不是對象的解決方法
- 各瀏覽器對document.getElementById等方法的實現(xiàn)差異解析
相關(guān)文章
Javascript常用運算符(Operators)-javascript基礎(chǔ)教程
Javascript常用運算符(Operators)-javascript基礎(chǔ)教程...2007-12-12深入理解JavaScript系列(42):設(shè)計模式之原型模式詳解
這篇文章主要介紹了深入理解JavaScript系列(42):設(shè)計模式之原型模式詳解,原型模式(prototype)是指用原型實例指向創(chuàng)建對象的種類,并且通過拷貝這些原型創(chuàng)建新的對象,需要的朋友可以參考下2015-03-03JavaScript 入門基礎(chǔ)知識 想學(xué)習(xí)js的朋友可以參考下
JavaScript 基礎(chǔ)知識 想學(xué)習(xí)js的朋友可以參考下2009-12-12javaScript復(fù)制功能調(diào)用實現(xiàn)方案
說到使用js實現(xiàn)點擊復(fù)制的功能,我下面想說的方法也是和網(wǎng)上的大同小異的。js實現(xiàn)是很簡單,最難的是兼容問題,畢竟用IE以外的人還是有很多的2012-12-12JavaScript中的prototype和constructor簡明總結(jié)
一直沒弄清楚JavaScript中的prototype和constructor屬性,今天看了看書,總算有點眉目了2014-04-04