document.documentElement.clientWidth


document.documentElement.clientWidth

摘自: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高)

 

以上摘自:http://blog.sina.com.cn/s/blog_6f1f9ead0100n1f6.html

經本地測試和研究再次對 document.documentElement.clientWidth 進行解釋:

 

 每一個html文件在瀏覽器中都會被解析為一個頁面,document.documentElement.clientWidth則是獲取本頁面的寬度。

下面進行舉例子說明:

1) 如果在瀏覽器全屏,並且打開的一個標簽頁中只包含一個頁面,則document.documentElement.clientWidth即本頁面的寬度=瀏覽器的寬度=屏幕可用工作區寬度:即window.screen.availWidth;

2)當調整瀏覽器為非全屏狀態時並且打開的一個標簽頁中只包含一個頁面:則document.documentElement.clientWidth即本頁面的寬度=瀏覽器的寬度!=屏幕可用工作區寬度:即window.screen.availWidth;

3)當打開的一個標簽頁中不只包含一個頁面:比如在一個頁面的frame中包含一個ifrme,該iframe指向另一個頁面,如下所示

則iframe指向頁面的document.documentElement.clientWidth不再等於瀏覽器寬度,而是等於ifame的寬度

 

個人理解:document.documentElement.clientWidth是該頁面的寬度

 

如有不合理,請留言,謝謝

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM