浅析rem

首先rem是css单位,相比于px固定的像素单位,rem更加的灵活,还有现在也比较好的vm。如果从未了解过,可以先过过眼

rem自适应。css3的rem设置字体大小

font size of the root element.

简单来说,rem就是根据html元素的字体大小来计算单位的。我们的需求就是说,根据不同的分辨率,我们元素的大小能够有所对应的变化,在视觉上能够做到很舒服的效果。想想我们在做pc端的时候,一般都是中间固定比如1200px像素,然后最小1200px,两边留白,这样我们无论放大缩小都不会影响效果。但是现在移动端各种屏幕的出现,适应性就更加的强烈。根据分辨率的不同让html的字体大小变化,我们在页面中写rem,由于rem是相对于根元素字体大小来计算的,那么就可以实现自适应的效果。

1.适配方式

适配方案采用rem布局, 根据屏幕分辨率大小不同,调整根元素html的font-size, 从而达到每个元素宽高自动变化,适配不同屏幕

2.使用 postcss-px2rem-exclude 插件

安装 npm install postcss-px2rem-exclude –save-dev

在项目根目录创建 postcss.config.js 文件

module.exports = {
  plugins: {
    autoprefixer: {},
    'postcss-px2rem-exclude': {
      remunit: 192
      // exclude: /node_modules|folder_name/i,
    }
  }
}

3.安装 flexible.js (建议放到本地)

安装命令  npm install lib-flexible

(function(win, lib) {
  var doc = win.document
  var docel = doc.documentelement
  var metael = doc.queryselector('meta[name="viewport"]')
  var flexibleel = doc.queryselector('meta[name="flexible"]')
  var dpr = 0
  var scale = 0
  var tid
  var flexible = lib.flexible || (lib.flexible = {})

  if (metael) {
    console.warn('将根据已有的meta标签来设置缩放比例')
    var match = metael
      .getattribute('content')
      // eslint-disable-next-line no-useless-escape
      .match(/initial\-scale=([\d\.]+)/)
    if (match) {
      scale = parsefloat(match[1])
      dpr = parseint(1 / scale)
    }
  } else if (flexibleel) {
    var content = flexibleel.getattribute('content')
    if (content) {
      // eslint-disable-next-line no-useless-escape
      var initialdpr = content.match(/initial\-dpr=([\d\.]+)/)
      // eslint-disable-next-line no-useless-escape
      var maximumdpr = content.match(/maximum\-dpr=([\d\.]+)/)
      if (initialdpr) {
        dpr = parsefloat(initialdpr[1])
        scale = parsefloat((1 / dpr).tofixed(2))
      }
      if (maximumdpr) {
        dpr = parsefloat(maximumdpr[1])
        scale = parsefloat((1 / dpr).tofixed(2))
      }
    }
  }

  if (!dpr && !scale) {
    // var isandroid = win.navigator.appversion.match(/android/gi);
    var isiphone = win.navigator.appversion.match(/iphone/gi)
    var devicepixelratio = win.devicepixelratio
    if (isiphone) {
      // ios下,对于2和3的屏,用2倍的方案,其余的用1倍方案
      if (devicepixelratio >= 3 && (!dpr || dpr >= 3)) {
        dpr = 3
      } else if (devicepixelratio >= 2 && (!dpr || dpr >= 2)) {
        dpr = 2
      } else {
        dpr = 1
      }
    } else {
      // 其他设备下,仍旧使用1倍的方案
      dpr = 1
    }
    scale = 1 / dpr
  }

  docel.setattribute('data-dpr', dpr)
  if (!metael) {
    metael = doc.createelement('meta')
    metael.setattribute('name', 'viewport')
    metael.setattribute('content', 'initial-scale=' + scale + ', maximum-scale=' + scale + ', minimum-scale=' + scale + ', user-scalable=no')
    if (docel.firstelementchild) {
      docel.firstelementchild.appendchild(metael)
    } else {
      var wrap = doc.createelement('div')
      wrap.appendchild(metael)
      doc.write(wrap.innerhtml)
    }
  }

  function refreshrem() {
    var width = docel.getboundingclientrect().width
    if (width / dpr > 540) {
      width = width * dpr
    }
    var rem = width / 10
    docel.style.fontsize = rem + 'px'
    flexible.rem = win.rem = rem
  }

  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 = 12 * dpr + 'px'
  } else {
    doc.addeventlistener(
      'domcontentloaded',
      function() {
        doc.body.style.fontsize = 12 * dpr + 'px'
      },
      false
    )
  }

  refreshrem()

  flexible.dpr = win.dpr = dpr
  flexible.refreshrem = refreshrem
  flexible.rem2px = function(d) {
    var val = parsefloat(d) * this.rem
    if (typeof d === 'string' && d.match(/rem$/)) {
      val += 'px'
    }
    return val
  }
  flexible.px2rem = function(d) {
    var val = parsefloat(d) / this.rem
    if (typeof d === 'string' && d.match(/px$/)) {
      val += 'rem'
    }
    return val
  }
})(window, window['lib'] || (window['lib'] = {}))

上面的代码与安装的flexible.js不同

修改了

  function refreshrem() {
    var width = docel.getboundingclientrect().width
    if (width / dpr > 540) {
      width = width * dpr
    }
    var rem = width / 10
    docel.style.fontsize = rem + 'px'
    flexible.rem = win.rem = rem
  }

在main.js中引入

import ‘路径/flexible.js’

总结

到此这篇关于vue项目适配大屏端的文章就介绍到这了,更多相关vue适配大屏端内容请搜索www.887551.com以前的文章或继续浏览下面的相关文章希望大家以后多多支持www.887551.com!