使用flexible.js完成rem适配

文章介绍了rem作为相对单位在响应式设计中的作用,特别是阿里团队的flexible.js库如何解决移动端不同设备的适配问题。flexible.js通过设置根元素字体大小实现动态适配,基于设备像素比(dpr)调整页面布局。同时,文章提到了根据屏幕宽度重置1rem的长度和对0.5px边框的支持检查。
摘要由CSDN通过智能技术生成

1、什么是rem?

  • rem:是指相对于根元素的字体大小的单位。
  • em:是指相对于父元素的字体大小的单位。

2、flexible.js

flexible.js是阿里团队开源的一个库。使用flexible.js轻松搞定各种不同的移动端设备兼容自适应问题。淘宝的移动端适配方案就是通过他实现的。

3、原理

  • flexible.js通过将页面划分为10份,每一份为1rem来解决的,比如原始设计图宽度为750px,那么1rem=75px,在写css样式时,将相应的尺寸写成rem单位即可实现适配。
  • 我们也根据之间的需求配置如何分割页面 setRemUnit()方法中修改

4、代码

// 来自 https://github.com/amfe/lib-flexible/blob/2.0/index.js
;(function flexible(window, document) {
  var docEl = document.documentElement
  // 获取当前显示设备的物理像素分辨率与CSS像素分辨率之比;
  var dpr = window.devicePixelRatio || 1
  console.log(window.devicePixelRatio)
  //根据分辨率调整全局字体大小
  function setBodyFontSize() {
    // html已完成加载,则立即调整字体大小,否则等待html加载完成再调整字体大小
    if (document.body) {
      document.body.style.fontSize = 12 * dpr + 'px'
    } else {
      // 监听DOMContentLoaded 事件——当初始的 HTML 文档被完全加载和解析完成之后触发,无需等待样式表
      document.addEventListener('DOMContentLoaded', setBodyFontSize)
    }
  }
  setBodyFontSize()

  // 根据屏幕宽度,重置1rem的长度为当前屏幕宽度的1/10
  function setRemUnit() {
    var rem = docEl.clientWidth / 10
    // 1rem的值永远为根元素的字体大小,所以此处通过调整全局字体大小来重置rem
    docEl.style.fontSize = rem + 'px'
  }

  setRemUnit()

  // 监听resize事件——屏幕大小发生变化时触发
  window.addEventListener('resize', setRemUnit)
  // 监听pageshow事件——显示页面时触发
  window.addEventListener('pageshow', function (e) {
    // 若是浏览器中点击后退时显示页面,则重置rem
    if (e.persisted) {
      setRemUnit()
    }
  })

  // 检测是否支持0.5px
  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)
  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

前端~初学者

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值