国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > JavaScript > 正文

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

2019-11-20 14:05:38
字體:
來源:轉載
供稿:網友

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

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 二连浩特市| 建始县| 天气| 马山县| 文安县| 大冶市| 玉田县| 绵阳市| 白水县| 堆龙德庆县| 阜南县| 岚皋县| 清水河县| 玛曲县| 平凉市| 邯郸市| 万宁市| 灵宝市| 工布江达县| 石楼县| 精河县| 永登县| 平和县| 达尔| 淅川县| 耿马| 五河县| 宜君县| 曲松县| 娱乐| 沽源县| 周口市| 合江县| 巴中市| 凤庆县| 恩施市| 梓潼县| 罗城| 阳山县| 泽库县| 永嘉县|