document.documentElement.clientWidthhtml
摘自:http://blog.sina.com.cn/s/blog_6f1f9ead0100n1f6.html瀏覽器
關於獲取各類瀏覽器可見窗口大小的一點點研究
<script>
function getInfo()
{
var s = "";
s = " 網頁可見區域寬:" document.body.clientWidth;
s = " 網頁可見區域高:" document.body.clientHeight;
s = " 網頁可見區域寬:" document.body.offsetWidth " (包括邊線和滾動條的寬)";
s = " 網頁可見區域高:" document.body.offsetHeight " (包括邊線的寬)";
s = " 網頁正文全文寬:" document.body.scrollWidth;
s = " 網頁正文全文高:" document.body.scrollHeight;
s = " 網頁被捲去的高(ff):" document.body.scrollTop;
s = " 網頁被捲去的高(ie):" document.documentElement.scrollTop;
s = " 網頁被捲去的左:" document.body.scrollLeft;
s = " 網頁正文部分上:" window.screenTop;
s = " 網頁正文部分左:" window.screenLeft;
s = " 屏幕分辨率的高:" window.screen.height;
s = " 屏幕分辨率的寬:" window.screen.width;
s = " 屏幕可用工做區高度:" window.screen.availHeight;
s = " 屏幕可用工做區寬度:" window.screen.availWidth;測試
s = " 你的屏幕設置是 " window.screen.colorDepth " 位彩色";
s = " 你的屏幕設置 " window.screen.deviceXDPI " 像素/英寸";
//alert (s);
}
getInfo();
</script>
在我本地測試當中:
在IE、FireFox、Opera下均可以使用
document.body.clientWidth
document.body.clientHeight
便可得到,很簡單,很方便。
而在公司項目當中:
Opera仍然使用
document.body.clientWidth
document.body.clientHeight
但是IE和FireFox則使用
document.documentElement.clientWidth
document.documentElement.clientHeight
原來是W3C的標準在做怪啊
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
若是在頁面中添加這行標記的話 在IE中:
document.body.clientWidth ==> BODY對象寬度
document.body.clientHeight ==> BODY對象高度
document.documentElement.clientWidth ==> 可見區域寬度
document.documentElement.clientHeight ==> 可見區域高度
在FireFox中:
document.body.clientWidth ==> BODY對象寬度
document.body.clientHeight ==> BODY對象高度
document.documentElement.clientWidth ==> 可見區域寬度
document.documentElement.clientHeight ==> 可見區域高度
?
在Opera中:
document.body.clientWidth ==> 可見區域寬度
document.body.clientHeight ==> 可見區域高度
document.documentElement.clientWidth ==> 頁面對象寬度(即BODY對象寬度加上Margin寬)
document.documentElement.clientHeight ==> 頁面對象高度(即BODY對象高度加上Margin高)
而若是沒有定義W3C的標準,則
IE爲:
document.documentElement.clientWidth ==> 0
document.documentElement.clientHeight ==> 0
FireFox爲:
document.documentElement.clientWidth ==> 頁面對象寬度(即BODY對象寬度加上Margin寬)document.documentElement.clientHeight ==> 頁面對象高度(即BODY對象高度加上Margin高)
Opera爲:
document.documentElement.clientWidth ==> 頁面對象寬度(即BODY對象寬度加上Margin寬)document.documentElement.clientHeight ==> 頁面對象高度(即BODY對象高度加上Margin高)spa
以上摘自:http://blog.sina.com.cn/s/blog_6f1f9ead0100n1f6.htmlhtm
經本地測試和研究再次對 document.documentElement.clientWidth 進行解釋:對象
每個html文件在瀏覽器中都會被解析爲一個頁面,document.documentElement.clientWidth則是獲取本頁面的寬度。blog
下面進行舉例子說明:ip
1) 若是在瀏覽器全屏,而且打開的一個標籤頁中只包含一個頁面,則document.documentElement.clientWidth即本頁面的寬度=瀏覽器的寬度=屏幕可用工做區寬度:即window.screen.availWidth;get
2)當調整瀏覽器爲非全屏狀態時而且打開的一個標籤頁中只包含一個頁面:則document.documentElement.clientWidth即本頁面的寬度=瀏覽器的寬度!=屏幕可用工做區寬度:即window.screen.availWidth;iframe
3)當打開的一個標籤頁中不僅包含一個頁面:好比在一個頁面的frame中包含一個ifrme,該iframe指向另外一個頁面,以下所示
則iframe指向頁面的document.documentElement.clientWidth再也不等於瀏覽器寬度,而是等於ifame的寬度
我的理解:document.documentElement.clientWidth是該頁面的寬度
若有不合理,請留言,謝謝