javascript檢測瀏覽器的縮放狀態實現代碼_javascript技巧

來源:互聯網
上載者:User

這裡所說的縮放不是指瀏覽器大小的縮放,而是指瀏覽器網頁內容的百分比縮放(按Ctrl和+號鍵或者-號鍵的縮放)。
檢測這種縮放有很種方法,QQ空間都通過flash來檢測瀏覽器是否處於縮放。這裡提供javascript的方法來檢測瀏覽器的縮放。
對於 IE6,就直接無視了,因為 IE6 只能對文本進行縮放。
先來說說瀏覽器提供的標準檢測介面,window.devicePixelRatio 是裝置上物理像素和裝置獨立像素的比例,該屬性就可以用於檢測網頁是否被縮放了。在普通的 PC 瀏覽器上,在預設無縮放的情況下其預設值是 1。目前Firefox、chrome等都得到了很好的支援。
好吧,接下來該說說 IE 的處理方法了。IE 提供了 window.screen.deviceXDPI 和 window.screen.logicalXDPI 兩個屬性,deviceXDPI 就是對應的裝置上的物理像素,而 logicalXDPI 就是對應了裝置獨立像素的比例。估計標準的檢測介面也只是基於 IE 這種方法的一種改進。這兩個屬性在 windows XP+ 以上的系統上的預設值都是 96,因為系統預設的就是 96dpi 。
對於以上兩種都不支援的瀏覽器,還可以利用window.outerWidth 和 window.innerWidth 這兩個屬性。outerWidth 返回的是視窗元素的外部實際寬度,innerWidth 返回的是視窗元素的內部實際寬度,這兩個寬度都包含了捲軸在內的寬度。
有了這些屬性基本就可以搞定 PC 瀏覽器上常見的瀏覽器了。實現代碼如下:

detectZoom 函數的傳回值如果是 100 就是預設縮放層級,大於 100 則是放大了,小於 100 則是縮小了。

function detectZoom (){   var ratio = 0,    screen = window.screen,    ua = navigator.userAgent.toLowerCase();   if (window.devicePixelRatio !== undefined) {      ratio = window.devicePixelRatio;  }  else if (~ua.indexOf('msie')) {      if (screen.deviceXDPI && screen.logicalXDPI) {      ratio = screen.deviceXDPI / screen.logicalXDPI;    }  }  else if (window.outerWidth !== undefined && window.innerWidth !== undefined) {    ratio = window.outerWidth / window.innerWidth;  }     if (ratio){    ratio = Math.round(ratio * 100);  }     return ratio;};

原創文章,轉載請註明: 轉載自前端開發

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.