rem自适应布局的js代码

转载:https://www.cnblogs.com/chenzhengyang/p/10935213.html

 

尺寸换算:1rem = 100px,调试屏幕宽度:750px(盒子的宽度设置为7.5rem,则在宽度为750px以下的移动设备,宽度 = 100%)

rem不兼容ie8和ie8以下

(function(designWidth, maxWidth) {

    var doc = document,

        win = window,

        docEl = doc.documentElement,

        remStyle = document.createElement("style"),

        tid;

    function refreshRem() {

        var width = docEl.getBoundingClientRect().width;

        maxWidth = maxWidth || 540;

        width > maxWidth && (width = maxWidth);

        var rem = width * 100 / designWidth;

        remStyle.innerHTML = 'html{font-size:' + rem + 'px;}';

    }

    if (docEl.firstElementChild) {

        docEl.firstElementChild.appendChild(remStyle);

    } else {

        var wrap = doc.createElement("div");

        wrap.appendChild(remStyle);

        doc.write(wrap.innerHTML);
        wrap = null;

    }

    //要等 wiewport 设置好后才能执行 refreshRem,不然 refreshRem 会执行2次;

    refreshRem();

    win.addEventListener("resize", function() {

        clearTimeout(tid); //防止执行两次

        tid = setTimeout(refreshRem, 300);

    }, false);



    win.addEventListener("pageshow", function(e) {

        if (e.persisted) { // 浏览器后退的时候重新计算

            clearTimeout(tid);

            tid = setTimeout(refreshRem, 300);

        }

    }, false);

    if (doc.readyState === "complete") {

        doc.body.style.fontSize = "16px";

    } else {

        doc.addEventListener("DOMContentLoaded", function(e) {

            doc.body.style.fontSize = "16px";

        }, false);

    }

})(750, 750);

 

posted @ 2020-03-20 17:26  我也不想那么菜  阅读(716)  评论(0编辑  收藏  举报