欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

vue项目适配大屏端的方法示例

程序员文章站 2022-06-25 10:00:13
浅析rem首先rem是css单位,相比于px固定的像素单位,rem更加的灵活,还有现在也比较好的vm。如果从未了解过,可以先过过眼rem自适应。css3的rem设置字体大小font size of t...

浅析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适配大屏端内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!

相关标签: vue 大屏 适配