原生js解决移动端1像素问题---1

(function () {
    var docEl = document.documentElement,
        viewPortEl = document.querySelector('meta[name="viewport"]'),
        dpr = window.devicePixelRatio || 1,
        maxWidth = 540,
        minWidth = 320;
    dpr = dpr >= 3 ? 3 : (dpr >= 2 ? 2 : 1);
    docEl.setAttribute('data-dpr', dpr);
    docEl.setAttribute('data-minWidth', minWidth);
    docEl.setAttribute('data-maxWidth', maxWidth);
    var scale = 1 / dpr,
        content = 'width=device-width,initial-scale=' + scale + ',maximum-scale=' + scale + ',minimum-scale=' + scale + ',user-scalable=no';
    if (viewPortEl) {
        viewPortEl.setAttribute('content', content);
    } else {
        viewPortEl = document.createElement('meta');
        viewPortEl.setAttribute('name', 'viewport');
        viewPortEl.setAttribute('content', content);
        document.head.appendChild(viewPortEl);
    }
    setRemUnit();
    window.addEventListener('resize', setRemUnit);

    function setRemUnit() {
        var ratio = 18.75
        var viewPortWidth = docEl.getBoundingClientRect().width || window.innerWidth;
        if (maxWidth && (viewPortWidth / dpr > maxWidth)) {
            viewPortWidth = maxWidth * dpr;
        } else if (minWidth && (viewPortWidth / dpr < minWidth)) {
            viewPortWidth = minWidth * dpr;
        }
        docEl.style.fontSize = viewPortWidth / ratio + 'px';
    }
})()
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值