當前位置:
首頁 >
前端技术
> javascript
>内容正文
javascript
javascript:使用document.getElementById读取数据为空分析
生活随笔
收集整理的這篇文章主要介紹了
javascript:使用document.getElementById读取数据为空分析
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
今天寫個網頁,想在頁面加載onLoad時,動態顯示由后臺其他程序傳來的數據時,用document.getElementById獲取控件對象總是為空。但是檢查了這個id確實是存在的。在網上查閱一番后才知道了其中的原因。
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:使用document.getElementById读取数据为空分析的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 第21届国际C语言混乱代码大赛获奖作品
- 下一篇: 第一课 前言 学PHP就是为了做网站