首頁 web前端 js教程 javascript檢測瀏覽器的縮放狀態實作程式碼_javascript技巧

javascript檢測瀏覽器的縮放狀態實作程式碼_javascript技巧

May 16, 2016 pm 04:35 PM
瀏覽器

這裡所說的縮放不是指瀏覽器大小的縮放,而是指瀏覽器網頁內容的百分比縮放(按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;
};
登入後複製

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

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

AI Hentai Generator

AI Hentai Generator

免費產生 AI 無盡。

熱門文章

R.E.P.O.能量晶體解釋及其做什麼(黃色晶體)
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.最佳圖形設置
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
R.E.P.O.如果您聽不到任何人,如何修復音頻
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
WWE 2K25:如何解鎖Myrise中的所有內容
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

如何通過CSS自定義resize符號並使其與背景色統一? 如何通過CSS自定義resize符號並使其與背景色統一? Apr 05, 2025 pm 02:30 PM

CSS自定義resize符號的方法與背景色統一在日常開發中,我們經常會遇到需要自定義用戶界面細節的情況,比如調...

如何在漸變背景的卡券佈局上實現缺口效果? 如何在漸變背景的卡券佈局上實現缺口效果? Apr 05, 2025 am 07:48 AM

實現卡券佈局的缺口效果在設計卡券佈局時,常常會遇到需要在卡券上添加缺口的需求,尤其是在背景為漸變色...

如何在網頁上正確顯示本地安裝的'荊南麥圓體”? 如何在網頁上正確顯示本地安裝的'荊南麥圓體”? Apr 05, 2025 pm 10:33 PM

在網頁中使用本地安裝的字體文件最近,我從網上下載了一種免費字體,並成功將其安裝到了我的系統中。現在...

負邊距在某些情況下為何未生效?如何解決這個問題? 負邊距在某些情況下為何未生效?如何解決這個問題? Apr 05, 2025 pm 10:18 PM

負邊距為何在某些情況下未生效?在編程過程中,CSS中的負邊距(negative...

Flex佈局下文字超出省略卻撐開容器?如何解決? Flex佈局下文字超出省略卻撐開容器?如何解決? Apr 05, 2025 pm 11:00 PM

Flex佈局下文字超出省略導致容器撐開的問題及解決方法在使用Flex...

如何獲取58同城工作頁面上的實時申請和瀏覽人數數據? 如何獲取58同城工作頁面上的實時申請和瀏覽人數數據? Apr 05, 2025 am 08:06 AM

如何在爬蟲時獲取58同城工作頁面的動態數據?在使用爬蟲工具爬取58同城的某個工作頁面時,可能會遇到這樣�...

如何使用 CSS 和 Flexbox 實現圖片和文本在不同屏幕尺寸下的響應式佈局? 如何使用 CSS 和 Flexbox 實現圖片和文本在不同屏幕尺寸下的響應式佈局? Apr 05, 2025 pm 06:06 PM

使用CSS實現響應式佈局當我們希望在網頁設計中實現不同屏幕尺寸下的佈局變化時,CSS...

為什麼Edge瀏覽器中的特定div元素無法顯示?如何解決這個問題? 為什麼Edge瀏覽器中的特定div元素無法顯示?如何解決這個問題? Apr 05, 2025 pm 08:21 PM

如何解決用戶代理樣式表導致的顯示問題?在使用Edge瀏覽器時,項目中的一個div元素無法顯示。經過查看,發�...

See all articles