本節代碼主要使用了Document對象關於窗口的一些屬性,這些屬性的主要功能和用法如下。
要得到窗口的尺寸,對於不同的浏覽器,需要使用不同的屬性和方法:若要檢測窗口的真實尺寸,在Netscape下需要使用Window的屬性;在IE下需要深入Document內部對body進行檢測;在DOM環境下,若要得到窗口的尺寸,需要注意根元素<html>的尺寸,而不是<body>元素。
Window對象的innerWidth屬性包含當前窗口的內部寬度。Window對象的innerHeight屬性包含當前窗口的內部高度。
Document對象的body屬性對應HTML文檔的<body>標簽。Document對象的documentElement屬性則表示 HTML文檔的根節點。
document.body.clientHeight表示HTML文檔所在窗口的當前高度。document.body. clientWidth表示HTML文檔所在窗口的當前寬度。
復制代碼 代碼如下:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<title>請調整浏覽器窗口</title>
<meta http-equiv="content-type" content="text/html; charset=gb2312">
</head>
<body>
<h2 align="center">請調整浏覽器窗口大小</h2><hr>
<form action="#" method="get" name="form1" id="form1">
<!--顯示浏覽器窗口的實際尺寸-->
浏覽器窗口 的實際高度: <input type="text" name="availHeight" size="4"><br>
浏覽器窗口 的實際寬度: <input type="text" name="availWidth" size="4"><br>
</form>
<script type="text/javascript">
<!--
var winWidth = 0;
var winHeight = 0;
function findDimensions() //函數:獲取尺寸
{
//獲取窗口寬度
if (window.innerWidth)
winWidth = window.innerWidth;
else if ((document.body) && (document.body.clientWidth))
winWidth = document.body.clientWidth;
//獲取窗口高度
if (window.innerHeight)
winHeight = window.innerHeight;
else if ((document.body) && (document.body.clientHeight))
winHeight = document.body.clientHeight;
//通過深入Document內部對body進行檢測,獲取窗口大小
if (document.documentElement && document.documentElement.clientHeight &&
document.documentElement.clientWidth)
{
winHeight = document.documentElement.clientHeight;
winWidth = document.documentElement.clientWidth;
}
//結果輸出至兩個文本框
document.form1.availHeight.value= winHeight;
document.form1.availWidth.value= winWidth;
}
findDimensions(); //調用函數,獲取數值
window.onresize=findDimensions;
//-->
</script>
</body>
</html>
運行該程序後,頁面出現兩個文本框,分別顯示窗口當前的寬度和高度,。當調整浏覽器窗口大小時,文本框中的數值會隨之改變,分別是不同時刻窗口的大小。
源程序解讀
(1)程序首先建立一個表單,包含兩個文本框,用於顯示窗口當前的寬度和高度,並且,其數值會隨窗口大小的改變而變化。
(2)在隨後的JavaScript代碼中,首先定義了兩個變量winWidth和winHeight,用於保存窗口的高度值和寬度值。
(3)然後,在函數findDimensions ( )中,使用window.innerHeight和window.innerWidth得到窗口的高度和寬度,並將二者保存在前述兩個變量中。
(4)再通過深入Document內部對body進行檢測,獲取窗口大小,並存儲在前述兩個變量中。
(5)在函數的最後,通過按名稱訪問表單元素,結果輸出至兩個文本框。
(6)在JavaScript代碼的最後,通過調用findDimensions ( )函數,完成整個操作。