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>