一、安装

npm install postcss-pxtorem --save-dev

二、增加postcss.config.js文件

在目录文件下增加postcss.config.js并添加相关配置

// https://github.com/michael-ciniawsky/postcss-load-config

module.exports = {
'plugins': {
// to edit target browsers: use "browserslist" field in package.json
'autoprefixer': {},
'postcss-pxtorem': {
rootValue: 16, // rem 相对于 px 转换的基准值
propList: ['*'], // 需要转换的 CSS 属性,* 表示全部
unitPrecision: 5, // 转换后的小数位数
exclude: (e) => { // 只对src/views/largeScreen文件进行px转rem,其他文件不转换
if(/src(\\|\/)views(\\|\/)largeScreen/.test(e)) {
return false
} else {
return true
}
}
}
}
} // npm相关配置介绍 `https://www.npmjs.com/package/postcss-pxtorem` 1.`rootValue`(数字 | 函数):表示根元素的字体大小,或者根据输入参数返回根元素的字体大小。 2.`unitPrecision`(数字):允许 REM 单位增长的小数位数。 3.`propList`(数组):可以从像素(px)转换为 REM 的属性列表。值必须完全匹配。
使用通配符 * 以启用所有属性。例如:['*']
在单词的开头或结尾使用 *。(['*position*'] 将匹配 background-position-y)
使用 ! 来排除某个属性。例如:['*', '!letter-spacing']
可以将 "not" 前缀与其他前缀结合使用。例如:['*', '!font*'] 4.`selectorBlackList`(数组):要忽略并保留为像素(px)的选择器。
如果值是字符串,它会检查选择器是否包含该字符串。
['body'] 将匹配 .body-class
如果值是正则表达式,它会检查选择器是否与正则表达式匹配。
[/^body$/] 将匹配 body,但不匹配 .body 5.`replace`(布尔值):替换包含 rem 的规则而不是添加回退。 6.`mediaQuery`(布尔值):允许在媒体查询中转换像素(px)。 7.`minPixelValue`(数字):设置要替换的最小像素值。 8.`exclude`(字符串、正则表达式、函数):要忽略并保留为像素(px)的文件路径。
如果值是字符串,它会检查文件路径是否包含该字符串。
'exclude' 将匹配 \project\postcss-pxtorem\exclude\path
如果值是正则表达式,它会检查文件路径是否与正则表达式匹配。
/exclude/i 将匹配 \project\postcss-pxtorem\exclude\path
如果值是函数,您可以使用排除函数返回 true,并将忽略该文件。
回调函数将文件路径作为参数传递,应返回一个布尔结果。
function (file) { return file.indexOf('exclude') !== -1; }

三、vue.config.js中配置

module.exports = {
//.... css: {
loaderOptions: {
postcss: {
config: {
path: './postcss.config.js'
}
}
}
}, //....
}

四、增加适配js、配置在main.js中

rem.js

//rem等比适配配置文件

//基准大小
const baseSize = 16 //设置 rem 函数
function setRem() {
//当前页面宽度相对于1920宽的缩放比例, 可根据自己需要修改
const scale = document.documentElement.clientWidth / 1920
//设置页面根节点字体大小, 字体大小最小为12
let fontSize = baseSize * Math.min(scale, 2) > 12 ? baseSize * Math.min(scale, 2) : 12
document.documentElement.style.fontSize = fontSize + 'px'
} //初始化
setRem()
//改变窗口大小重新设置rem
window.onresize = function () {
setRem()
}

main.js

import './utils/rem'  // 我文件放在utils下,引入即可

五、总结

以上是 postcss-pxtorem 插件的一些配置选项的说明。针对某页面固定使用,通过exclude字段配置。

px转rem适配方案之postcss-pxtorem的更多相关文章

  1. 谈谈我的移动端rem适配方案

    最近有点怀疑人生,毕竟一个人写前端,有时候会怀疑自己理解的一些东西包括用法有没有符合标准.趁着这阵子闲下来,翻了翻别人的rem适配博客,发现有点绕口,怪自己是个强迫症,啥都要自己去试试结果并从中理解, ...

  2. H5 端 rem 适配方案与 viewport 适配

    H5 端 rem 适配方案与 viewport 适配 rem rem 是 CSS3 新增的一个相对单位(root em,根 em) 只根据当前页面 HTML 页面的 font-size 设置,如果根目 ...

  3. em与rem之间的区别以及移动设备中的rem适配方案

    em与rem之间的区别: 共同点: 它们都是像素单位 它们都是相对单位 不同点: em大小是基于父元素的字体大小 rem大小是基于根元素(html)的字体的大小 实例: <!DOCTYPE ht ...

  4. 最佳移动端h5自适应rem适配方案

    一.利用lib-flexible.postcss-plugin-px2rem插件 进行移动端rem适配. 1.第一 引入lib-flexible . 安装lib-flexible: npm i lib ...

  5. vue中使用第三方UI库的移动端rem适配方案

    需求:使用vue-cli脚手架搭建项目,并且使用第三方的UI库(比如vant,mint ui)的时候,因为第三方库用的都是用px单位,无法使用rem适配不同设备的屏幕. 解决办法:使用px2rem-l ...

  6. rem适配方案

    页面布局单位计算 一般有两大类:绝对长度单位和相对长度单位 绝对长度单位: px 像素:是显示屏上显示的每一个小点,为显示的最小单位 in 英寸,1in = 96px cm 厘米,1cm = 37.8 ...

  7. 淘宝rem适配方案

    /*px 转化换 rem ,转化是 10 .比如:你的设计图为750,那么就 750 / 75 = 10 rem.设计图中你量尺寸都要除 75 就是 rem值.再比如量的设计图按钮宽度 66px,那么 ...

  8. 移动web开发适配方案之Rem

    移动端为什么要做适配 移动端相对PC端来说大部分浏览器内核都是基于Webkit的,所以大部分都支持CSS3的最新语法.但是由于手机的屏幕尺寸和分辨率都不太一样(尤其是安卓),所以不得不对不同分辨率的手 ...

  9. vue项目中使用了vw适配方案,引入第三方ui框架mint-ui时,适配问题解决

    问题分析: 一般第三方ui框架用的都是不同的适配方式,如果我们使用了vw适配,那么在使用mint-ui框架时,就会发现px单位会被转换成vw,从而导致样式变小的问题,如图 解决方案 网上看到了很多种解 ...

  10. 移动端高清适配方案(解决图片模糊问题、1px细线问题)

    本文介绍了移动端适配的3种方法,以及移动端图片模糊问题和1px细线问题的解决方法.当然了,在这之前先整理了与这些方法相关的知识:物理像素.设备独立像素.设备像素比和viewport. >> ...

随机推荐

  1. Linux基础命令3:通过名称指定文件、创建文件目录

    描述Linux文件系统层次结构概念 /root(root的home目录)/home/username(其它普通用户的home目录)/bin, /usr/bin, /usr/local/bin命令存放处 ...

  2. 4. 使用sql查询excel内容

    1. 简介 我们在前面的文章中提到了calcite支持csv和json文件的数据源适配, 其实就是将文件解析成表然后以文件夹为schema, 然后将生成的schema注册到RootSehema(Roo ...

  3. Oracle数据库只能127.0.0.1连接,无法局域网远程通过IP访问

    今天使用Oracle时遇到一个问题,连接字符串中IP配置成127.0.0.1时可能正常访问数据库,当配置成实际IP地址时连接数据库失败.然后 telnet IP 1521 失败. 解决方案: 1. 打 ...

  4. 一个简易socket通信结构

    服务端 基本的结构 工作需要又需要用到socketTCP通讯,这么多年了,终于稍微能写点了.让我说其实也说不出个啥来,看了很多的异步后稍微对异步socket的导流 endreceive后 再begin ...

  5. Hetao P3804 Cut 题解 [ 蓝 ] [ AC 自动机 ] [ 差分 ]

    Cut:AC 自动机简单题. 思路 看见多个模式串以及求前缀,很显然能想到构建一个 AC 自动机. 那么在用 \(T\) 查询时,当前指针的深度就是该位置的最长前缀匹配长度.这个在字典树 insert ...

  6. [BZOJ3786] 星系探索 题解

    题目链接:\(BZOJ\) 本题通过 \(dyf\_DYF\) 的题解理解 \(ETT\),代码则借鉴 \(lcyfrog\) 的题解,图片则使用了何太狼的题解.在此笔者感谢这三位神犇. 声明变量: ...

  7. npm i 下载太慢

    1.在项目内部进入终端 2.输入:npm config set registry https://registry.npmmirror.com 修改npm下载地址为淘宝 3.然后再执行 npm i 进 ...

  8. nginx出现: [error] open() "/usr/local/nginx/logs/nginx.pid" failed错误

    问题情况 登陆服务器之后进到nginx使用./nginx -s reload重新读取配置文件,发现报==nginx: [error] open() "/usr/local/nginx/log ...

  9. 给Typecho加上心知天气-网页天气插件

    给你的博客添加个知心天气的天气预报,代码看下面 <!-- 知心天气--> <div id="tp-weather-widget" class="navb ...

  10. Zookeeper - 客户端常用命令

    查看客户端命令帮助信息 查看Zookeeper的版本 查看使用过的历史命令 查看根目录下的znode 创建znode 查看节点信息 修改znode的内容 删除znode 关闭连接 连接客户端 退出客户 ...