【vue项目适配可借助于插件lib-flexible 和postcss-px2rem】

前言:vue项目适配可借助于插件lib-flexible 和postcss-px2rem。

lib-flexible插件的作用:根据屏幕尺寸不同设置html根标签的字体大小,1rem即等于根标签的字体大小。

postcss-px2rem插件的作用:将px转为rem,如此以来我们可以在开发的过程中使用px单位。

注意:该插件不适用于行内样式,如使用行内样式,postcss-px2rem 则不能将px转为rem

具体使用方法如下:

一、下包(使用yarn或者npm都可)

1、yarn 命令下包

javascript 复制代码
yarn add lib-flexible postcss-px2rem

2、npm命令下包

javascript 复制代码
npm i lib-flexible postcss-px2rem

二、更改插件配置

1、更改lib-flexible插件的配置

找到node_modules文件夹下的lib-flexible下的flexible.js文件,修改refreshRem 函数

javascript 复制代码
 function refreshRem(){
        var width = docEl.getBoundingClientRect().width;
        if (width / dpr > 540) {
            width = 540* dpr;
        }
        var rem = width / 10;
        docEl.style.fontSize = rem + 'px';
        flexible.rem = win.rem = rem;
    }

改为

javascript 复制代码
 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;
    }

2、配置postcss-px2rem

在vue.config.js文件中追加如下代码

javascript 复制代码
const px2rem = require('postcss-px2rem')
const postcss = px2rem({
  remUnit: 192, // 设计稿十等分后的值1rem=192px
  remPrecision: 6 // 转化后小数点位数
})
 
module.exports = {
  css: {
    // PC分辨率端适配
    loaderOptions: {
      css: {},
      postcss: {
        plugins: {
          postcss
        }
      }
    }
  }
}

注意:修改vue.config.js代码需要重启项目

三、重启项目测试

f12控制台检查html标签,当html标签设置了font-size即说明lib-flexible插件生效

检查样式px是否转为rem,如转为rem即生效

ps:在适配过程中,刚开始我的单位px未转化为rem,最后将vue/cli版本从5.0.8降低为4.5.15才生效。

如使用 px2rem-loader 插件适配,采用如下方式配置,则注意px2rem-loader插件配置方式对scss代码并不生效,需为css,不能使用scss

javascript 复制代码
 chainWebpack: config => {
    config.module
      .rule('css')
      .test(/\.css$/)
      .oneOf('vue')
      .resourceQuery(/\?vue/)
      .use('px2rem')
      .loader('px2rem-loader')
      .options({
        remUnit: 192, // 根据视觉稿,rem为px的十分之一,1920px  192 rem
        remPrecision: 8// 换算的rem保留几位小数点
      })
  }

原文链接:https://blog.csdn.net/weixin_45371730/article/details/126404369

相关推荐
ObjectX前端实验室10 分钟前
【图形编辑器架构】🧠 Figma 风格智能选择工具实现原理【猜测】
前端·react.js
天桥下的卖艺者12 分钟前
R语言基于shiny开发随机森林预测模型交互式 Web 应用程序(应用程序)
前端·随机森林·r语言·shiny
技术钱22 分钟前
vue3 两份json数据对比不同的页面给于颜色标识
前端·vue.js·json
路很长OoO31 分钟前
Flutter 插件开发实战:桥接原生 SDK
前端·flutter·harmonyos
Flash Dog34 分钟前
【Vue】——路由
vue.js
开水好喝1 小时前
Code Coverage Part I
前端
DoraBigHead2 小时前
🧭 React 理念:让时间屈服于 UI —— 从同步到可中断的演化之路
前端·javascript·面试
羊羊小栈2 小时前
基于「多模态大模型 + BGE向量检索增强RAG」的航空维修智能问答系统(vue+flask+AI算法)
vue.js·人工智能·python·语言模型·flask·毕业设计
敢敢J的憨憨L2 小时前
GPTL(General Purpose Timing Library)使用教程
java·服务器·前端·c++·轻量级计时工具库
喝拿铁写前端2 小时前
Vue 组件通信的两种世界观:`.sync` 与普通 `props` 到底有什么不同?
前端·vue.js·前端框架