美文网首页
vue less rem自适应

vue less rem自适应

作者: 懒懒猫 | 来源:发表于2022-08-08 18:14 被阅读0次

如果用不了可能是版本问题,实在不行建议尝试下,以下版本
"less": "^3.0.4", "less-loader": "^5.0.0"
less-loader安装失败的话,后面添加--legacy-peer-deps
npm install less-loader@5.0.0 --save --legacy-peer-deps
flexible.js

(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 () {
        // 这里默认是10等份,手动改为24,此时1rem=1920/24px即80px。(设计稿是1920px的)
        var rem = docEl.clientWidth / 24
        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)

home.js

<script>
import '@/utils/flexible'
...
</script>
<style lang="less" scoped>
@r: 80rem;
...
  height: 688 /@r; //688px
...
</style>

相关文章

  • vue less rem自适应

    如果用不了可能是版本问题,实在不行建议尝试下,以下版本"less": "^3.0.4", "less-loader...

  • vue-cli中rem的使用

    rem自适应布局插件配置 vue-cli插件配置 插件:lib-flexible 下载:npm install l...

  • vue-cli中rem的使用

    rem自适应布局插件配置 vue-cli插件配置 插件:lib-flexible 下载:npm install l...

  • vue 中使用rem布局

    要想移动端适配 并使用 rem 您需要先看这篇文章,配置好less ➡️在vue 中使用 less,就可以使用re...

  • vue项目框架(移动端)

    零.框架说明 主体技术用得是vue全家桶+webpack 页面自适应是基于rem 跨域问题用proxyTable解...

  • HTML学习之图片字体适配

    移动h5 图片字体等适配WebApp开发之--"rem"单位Rem实现自适应初体验手机端页面自适应解决方案—rem布局

  • vue 中使用rem布局

    在用vue或react等工具搭建一个移动端项目时,怎样做到自适应呢? 当然选择rem布局比较方便快捷.此处已vue...

  • maizuo-mobile技术栈

    目录 样式重置和公共样式 svg-icon 移动端适配lib-flexible用rem编写移动端自适应网页 vue...

  • vue中用rem自适应

    1.在 的App.vue中写如下代码: