• 淘宝rem适配方案


    /*
    px 转化换 rem ,转化是 10 。
    比如:
    你的设计图为750,那么就 750 / 75 = 10 rem。
    设计图中你量尺寸都要除 75 就是 rem值。再比如量的设计图按钮宽度 66px,那么计算:66 / 75 = 0.88rem
    比如2:
    设计图为900,那么 900 / 90 = 10rem;
    设计图中所有量的尺寸都得除 90 就等于 rem的之。
    以此类推
    */

    ;(function flexible (window, document) {
    var docEl = document.documentElement
    var dpr = window.devicePixelRatio || 1

    // adjust body font size
    function setBodyFontSize () {
    if (document.body) {
    document.body.style.fontSize = (12 * dpr) + 'px'
    }
    else {
    document.addEventListener('DOMContentLoaded', setBodyFontSize)
    }
    }
    setBodyFontSize();

    // set 1rem = viewWidth / 10
    function setRemUnit () {
    var rem = docEl.clientWidth / 10
    docEl.style.fontSize = rem + 'px'
    }

    setRemUnit()

    // reset rem unit on page resize
    window.addEventListener('resize', setRemUnit)
    window.addEventListener('pageshow', function (e) {
    if (e.persisted) {
    setRemUnit()
    }
    })

    // detect 0.5px supports
    if (dpr >= 2) {
    var fakeBody = document.createElement('body')
    var testElement = document.createElement('div')
    testElement.style.border = '.5px solid transparent'
    fakeBody.appendChild(testElement)
    docEl.appendChild(fakeBody)
    if (testElement.offsetHeight === 1) {
    docEl.classList.add('hairlines')
    }
    docEl.removeChild(fakeBody)
    }
    }(window, document))

  • 相关阅读:
    软件设计文档
    java基础路线与详细知识点
    hdu 2203 亲和串 kmp
    UVALive 6915 J
    UVALive 6911 F
    UVALive 6906 A
    hdu 3746 Cyclic Nacklace KMP
    hdu 1686 Oulipo kmp算法
    hdu1711 Number Sequence kmp应用
    hdu4749 kmp应用
  • 原文地址:https://www.cnblogs.com/shangjun6/p/11905530.html
Copyright © 2020-2023  润新知