1. 程式人生 > >螢幕大小改變或首次載入計算html根元素 fontsize

螢幕大小改變或首次載入計算html根元素 fontsize

/**
 * @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);