1. 程式人生 > >關於JavaScript的innerWidth與innerHeight

關於JavaScript的innerWidth與innerHeight

開發者選項 w3c round wid ber scrip .com 20px 解析

innerWidth與innerHeight屬性 說明:window對象的只讀屬性,聲明了窗口的文檔顯示區的高度和寬度,以像素(px)為計量單位。 (註意:這裏的寬度和高度不包括菜單欄、工具欄以及滾動條等的高度)

下面便對這兩個屬性進行驗證:

屏幕分辨率為:1920x1080 瀏覽器:QQ瀏覽器(內核是Chrome) 代碼如下:

 var width=window.innerWidth,height=window.innerHeight;         //分別定義width和height接收窗口的高和寬
     alert(width);        //窗口的寬度 1920px
     alert(height);     //
窗口的高度 950px

innerWidth因為瀏覽器兩旁沒有遮擋物,所以完美的得到了屏幕的寬度1920,而innerHeight因為瀏覽器上面有工具欄,顯示屏又有任務欄,所以被擠掉了130px

這次博主依次幹掉了任務欄(其實就是隱藏了)和工具欄中的標簽頁 並按下F12加上了開發者選項 再次進行測試:

     /*————————幹掉任務欄後————————*/
     var width=window.innerWidth,height=window.innerHeight;        
     alert(width);        //寬度沒有變化,還是1920px
     alert(height);     //
而窗口的高度990px,表明任務欄占40px(任務欄的默認高度) 導致沒有獲取到全部高度 /*————————又幹掉標簽頁後,並加上開發者選項後————————*/ var width=window.innerWidth,height=window.innerHeight; alert(width); //1381px,說明瀏覽器開發者選項,對innerWidth有影響 1920-1381=549px alert(height);   //而窗口的高度979px,任務欄占40px,標簽頁占了11px(990-979) 而由此得出剩下的工具欄占了1080-979=101px

結論:說明innerHeight和innerWidth確實只計算顯示窗口像素,如果沒有菜單欄、工具欄等外部因素擠壓它,它就會自動延伸,而如果有就只按顯示窗體走

測試完外部的因素,下面測試一下內部的因素滾動條

  <html>
        <head>
        <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
                
        <title>測試innerHeight屬性</title>
            
        </head>
        
        <body>
        <div style="width:500px;height:1300px;background-color:red;"></div>
        
        <script>        
                window.onload=function(){
                    /*————————div超出長度,帶著滾動條後————————*/
                    var width=window.innerWidth,height=window.innerHeight;        
                     alert(width);        //窗口的寬度 1920px
                     alert(height);     //窗口的高度  950px
            }
            </script>
        </body>
   </html>

結論:說明內部的滾動條對innerWidth並沒有影響,即使存在對width也沒有影響,依舊是1920px

最終結論:innerHeight和innerWidth獲取的是窗體的高與寬,外部因素如(瀏覽器開發者選項,收藏夾)會對它有影響,而內部因素(滾動條)則對其沒有影響

下面說一下槽點最多的IE,關於IE兼容性的問題,可以這樣解決

//兼容代碼可以這樣子寫
var width = window.innerWidth,height = window.innerHeight;

if (typeof width != ‘number‘) {       //如果類型不為number,表示該瀏覽器不支持innerWidth屬性

    if (document.compatMode == ‘CSS1Compat‘) {          //CSS1Compat:判斷是否為標準兼容模式。

        width = document.documentElement.clientWidth;

        height = document.docuementElement.clientHeight;

    } else {  //不是標準模式,則有可能是IE6或及其以下版本(早期的瀏覽器對css進行解析時,並未遵守W3C標準)

        width = document.body.clientWidth;            //網頁可見區域寬

        height = document.body.clientHeight;          //網頁可見區域高
}
        alert(width);
        alert(height);

文章大概結束了(第一次發文,有理解不對的地方還望大神指教)

關於JavaScript的innerWidth與innerHeight