rem.js

<script>
(function remSetting (win) {
  const doc = win.document
  const docEl = doc.documentElement
  let timer
  const refreshRem = function() {
    let width = docEl.getBoundingClientRect().width  
    if (width > 750) {
      width = 750
    } else if (width < 320) { 
      width = 320
    }
    const rem = width / 7.5   // width/750/100 根据实际调整
    docEl.style.fontSize = rem + 'px'
  }

  win.addEventListener('resize', () => {
    clearTimeout(timer)
    timer = setTimeout(refreshRem, 300)
  }, false)

  win.addEventListener('pageshow', (e) => {
    if (e.persisted) {
      clearTimeout(timer)
      timer = setTimeout(refreshRem, 300)
    }
  }, false)

  if (doc.readyState === 'complete') {
    doc.body.style.fontSize = '12px'
  } else {
    doc.addEventListener('DOMContentLoaded', () => {
      doc.body.style.fontSize = '12px'
    }, false)
  }
  refreshRem()
}(window))

</script>
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值