螢幕大小改變或首次載入計算html根元素 fontsize
阿新 • • 發佈:2018-12-23
/** * @file 檔案的描述 * @author Y50 <[email protected]> * @copyright * @license Released under the Commercial license. * @since 1.0.1 * @version 1.0.1 - 2015-9-8 */ (function (doc, win) { 'use strict'; var devicePixelRatio = win.devicePixelRatio, viewport = document.createElement('meta'); viewport.name='viewport'; document.getElementsByTagName('head')[0].appendChild(viewport); //讓螢幕按照真實的畫素進行渲染 此時1px=1dip 獨立畫素=實際畫素 //viewport.content='initial-scale='+1/devicePixelRatio+', maximum-scale='+1/devicePixelRatio+', minimum-scale='+1/devicePixelRatio+', user-scalable=no'; if (devicePixelRatio === 2) { viewport.content='initial-scale=0.5, maximum-scale=0.5, minimum-scale=0.5, user-scalable=no'; } else if (devicePixelRatio === 3) { viewport.content='initial-scale=0.3333333333, maximum-scale=0.3333333333, minimum-scale=0.3333333333, user-scalable=no'; } else { viewport.content='width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=no'; } var docEl = doc.documentElement, resizeEvt = 'orientationchange' in window ? 'orientationchange' : 'resize', recalc = function () { var clientWidth = docEl.clientWidth; if (!clientWidth) { return; } docEl.style.fontSize = 100 * (clientWidth / 375) + 'px'; }; // Abort if browser does not support addEventListener if (!doc.addEventListener) return; //螢幕方向改變或者螢幕大小重新調整後換算 html根元素fontsize 分別對應手機 和 PC win.addEventListener(resizeEvt, recalc, false); //載入頁面結束後換算文件根元素的fontsize doc.addEventListener('DOMContentLoaded', recalc, false); })(document, window);