postcss-px-to-viewport 从入坑到放弃 (nuxt3搭建响应式官网解决方案 )
前沿
什么是 postcss-px-to-viewport
将px单位转换为视口单位的 (vw, vh, vmin, vmax) 的 PostCSS 插件。
为什么使用 postcss-px-to-viewport
在pc端盛行的时代 ,如果你不想去适配更多的pc端代码,可以采用它。
由于nuxt3本身已带postcss,所以无需额外安装postcss。

安装
如何在nuxt3中使用postcss-px-to-viewport插件?首先安装postcss-px-to-viewport插件
# 使用npm安装
npm install postcss-px-to-viewport --save-dev# 使用yarn进行安装
yarn add -D postcss-px-to-viewport
安装完毕会在 package.json 代码中显示
# package.json"devDependencies": {"postcss-px-to-viewport": "^1.1.1"}
使用
nuxt.config 配置信息
# nuxt.config.ts
import postcssConfig from "./utils/postcssConfig";
export default defineNuxtConfig({// 配置 PostCSSpostcss: postcssConfig
})
postcssConfig文件配置信息
# postcss 插件配置: postcss-px-to-viewport
export default {plugins: {"postcss-px-to-viewport": {// 需要转换的单位,默认为"px"unitToConvert: "px",// 设计稿的视口宽度viewportWidth: 1920,// 单位转换后保留的精度unitPrecision: 5,// 能转化为vw的属性列表propList: ["*"],// 希望使用的视口单位viewportUnit: "vw",// 字体使用的视口单位fontViewportUnit: "vw",// 需要忽略的CSS选择器,不会转为视口单位,使用原有的px等单位。selectorBlackList: [".ignore", ".hairlines"],// 设置最小的转换数值,如果为1的话,只有大于1的值会被转换minPixelValue: 1,// 媒体查询里的单位是否需要转换单位mediaQuery: false,// 是否直接更换属性值,而不添加备用属性replace: true,// 忽略某些文件夹下的文件或特定文件,例如 'node_modules' 下的文件exclude: [/node_modules/, /dist/, /.output/, /.nuxt/, /.vscode/],// 如果设置了include,那将只有匹配到的文件才会被转换include: [/pages/, /assets\/styles\/*/],// 是否添加根据 landscapeWidth 生成的媒体查询条件 @media (orientation: landscape)landscape: false,// 横屏时使用的单位landscapeUnit: "vw",// 横屏时使用的视口宽度landscapeWidth: 1338}}
};
校验
这个脚本可以将你CSS中的px单位转化为vw,1vw等于1/100视口宽度。
先来看看这段代码在浏览器被编译后的效果
# 源scss代码段
.item {position: relative;margin: 15px 0.6%;padding: 12px;width: 23.6%;height: 300px;border-radius: 10px;background-color: #ffffff;overflow: hidden;transition: all 200ms linear;
}
# 在浏览器开发者模式打开查看
.content-container .content-list .news-list .item[data-v-52cd24e9] {position: relative;margin: 0.78125vw 0.6%;padding: 0.625vw;width: 23.6%;height: 15.625vw;border-radius: 0.52083vw;background-color: #ffffff;overflow: hidden;-webkit-transition: all 200ms linear;-o-transition: all 200ms linear;transition: all 200ms linear;
}
以 margin 为例,可以计算得出 margin-top & margin-bottom 为 15px 的值经过编译后计算得出 15 / 1920 = 0.0078125 ,验证后正好是设定的viewportWidth:1920视口的1/100。
1、%单位未被编译,因为我们并未设定%纳入转换的单位范围。
2、如果你不想line-height: ?? px;被纳入编译范畴,建议采用倍率,如line-height: 1.42,当然border-radius可以采用%实现;
3、如果你是使用媒体分辨查询器,记得在其他媒体下要设定好width、height、border-radius(px)、line-height、margin、padding、font-size关键属性。
4、如果你不需要把字体大小纳入编译范畴,可以配置成这样: propList: ['*', '!font*'] ,将不转换font-size以及font-weight等属性。
移动端适配
说了这么久,怎么没看到移动端相关配置呢?马上就来:
只要你在postcssConfig.ts配置项,给 mediaQuery设置为 false,就行了。
结合我上面提到的第3点联合去实现移动端响应。
因为使用这个插件相当于使用了两套代码,所以我提出第3点就是能够尽量去继承pc端属性,而不是继承被编译的属性值。
有时候,我们会为复杂的导航栏去做两套代码。那么这时候如果你不加以阻止,那么移动端的代码会被 postcss-px-to-viewport 污染。这里我有两种方式实现:
1、通过配体查询适配包裹它
# $mobileMaxWidth 是我设置的scss变量,值=768
@media screen and (max-width: $mobileMaxWidth) {
// 移动端导航栏...
}
2、通过postcssConfig.ts配置项 , 忽略某些文件夹下的文件或特定文件
exclude (Array or Regexp) 忽略某些文件夹下的文件或特定文件,例如 'node_modules' 下的文件
- 如果值是一个正则表达式,那么匹配这个正则的文件会被忽略
- 如果传入的值是一个数组,那么数组里的值必须为正则
# 忽略移动端导航栏样式表
exclude: [/\/assets\/styles\/page\/webapp/],
当然,除了可以忽略文件的编译,也可以 做到匹配文件 需要的编译。
⚠️exclude和include是可以一起设置的,将取两者规则的交集。
同时,也可以设置需要编译时,所需要忽略的样式。
⚠️这里有两种模式,作用类似注释,但是这里 /* px-to-viewport-ignore-next */ 不会像多行注释这么优雅,他只对下一行不转义。
# You can use special comments for ignore conversion of single lines:/* px-to-viewport-ignore-next */ — on a separate line, prevents conversion on the next line.
/* px-to-viewport-ignore */ — after the property on the right, prevents conversion on the same line.
读到这里或许你已经在实操了,就会发现这个bug。如果你的版本是:"postcss-px-to-viewport": "^1.1.1"。
你需要到官网,找到index.js文件

拷贝index.js内容到你的依赖:\node_modules\postcss-px-to-viewport\index.js 文件并替换它。

具体请阅读:/* px-to-viewport-ignore-next */ 注释无效是为什么 · Issue #72 · evrone/postcss-px-to-viewport (github.com)
⚠️替换之后,记得重新npm run dev。(注意事项)
富文本处理
这里,或许会发现其他都不错,但是通过后台上传的富文本style他会受到污染吗?
不会的,postcss-px-to-viewport 并不会对style做编译,所以富文本时常通过style渲染的样式可以放心。
当然,也有使用默认字体大小的,这样就会受样式表的父类设定的font-size影响,你只要给父类设定字体大小就可以了,移动端同理给@media 设定字体大小。
注意事项
- 每次修改postcssConfig.ts配置项的时候需要重新启动项目,因为你触碰了nuxt.config.ts配置。
- 如果你刚开始并没有采用postcss-px-to-viewport去实现响应式布局的方案,你后续只要检查移动端适配就行啦,pc端交给它处理。
如果以上能够满足你的业务需求,就无需往下看了。
重点
这是控制台输出的警告日志:
WARN postcss-px-to-viewport: postcss.plugin was deprecated. Migration guide: 14:20:01
https://evilmartians.com/chronicles/postcss-8-plugin-migration
意思是你所使用的 postcss-px-to-viewport 已经不在维护啦~😂
真是出来旅游不看攻略,xx 🙃
现在请你毫不留情地在终端对它:npm uninstall postcss-px-to-viewport 。
经过比对,我们的nuxt3已经是postcss 8 版本的:


所以,我们为何不用 npm i postcss-px-to-viewport-8-plugin 呢🤙
安装 postcss-px-to-viewport-8-plugin
npm i postcss-px-to-viewport-8-plugin
幸好postcss8的插件参数与之前的postcss-px-to-viewport配置是一致的。😃
安装后,只需要修改:
# postcssConfig.ts
# 将原先 postcss-px-to-viewport 修改成 “postcss-px-to-viewport-8-plugin”
export default {plugins: {"postcss-px-to-viewport-8-plugin": {}}
}
这时候你在npm run dev,终端不再有警告。并且 /* px-to-viewport-ignore-next */、 /* px-to-viewport-ignore */也不再需要上面那样操作了(修改index.js),直接在样式表就能用。
参数说明
最后附上参数说明
| 参数 | 说明 | 类型 | 默认值 |
|---|---|---|---|
unitToConvert | 需要转换的单位,默认为 px | string | px |
viewportWidth | 设计稿的视口宽度,如传入函数,函数的参数为当前处理的文件路径,函数返回 undefind 跳过转换 | number | Function | 320 |
unitPrecision | 单位转换后保留的精度 | number | 5 |
propList | 能转化为 vw 的属性列表 | string[] | ['*'] |
viewportUnit | 希望使用的视口单位 | string | vw |
fontViewportUnit | 字体使用的视口单位 | string | vw |
selectorBlackList | 需要忽略的 CSS 选择器,不会转为视口单位,使用原有的 px 等单位 | string[] | [] |
minPixelValue | 设置最小的转换数值,如果为 1 的话,只有大于 1 的值会被转换 | number | 1 |
mediaQuery | 媒体查询里的单位是否需要转换单位 | boolean | false |
replace | 是否直接更换属性值,而不添加备用属性 | boolean | true |
landscape | 是否添加根据 landscapeWidth 生成的媒体查询条件 @media (orientation: landscape) | boolean | false |
landscapeUnit | 横屏时使用的单位 | string | vw |
landscapeWidth | 横屏时使用的视口宽度,,如传入函数,函数的参数为当前处理的文件路径,函数返回 undefind 跳过转换 | number | 568 |
exclude | 忽略某些文件夹下的文件或特定文件,例如 node_modules 下的文件,如果值是一个正则表达式,那么匹配这个正则的文件会被忽略,如果传入的值是一个数组,那么数组里的值必须为正则 | Regexp | undefined |
include | 需要转换的文件,例如只转换 'src/mobile' 下的文件 (include: /\/src\/mobile\//),如果值是一个正则表达式,将包含匹配的文件,否则将排除该文件, 如果传入的值是一个数组,那么数组里的值必须为正则 | Regexp | undefined |
相关文章:
postcss-px-to-viewport 从入坑到放弃 (nuxt3搭建响应式官网解决方案 )
前沿 什么是 postcss-px-to-viewport 将px单位转换为视口单位的 (vw, vh, vmin, vmax) 的 PostCSS 插件。 为什么使用 postcss-px-to-viewport 在pc端盛行的时代 ,如果你不想去适配更多的pc端代码,可以采用它。 由于nuxt3本身已带postcss,所…...
C语言从入门到入门
一、引言 C语言是一种通用的、过程式的计算机编程语言,支持结构化编程、词汇变量作用域和递归等功能,其设计提供了低级别的存取权限,并且要求程序员管理所有的内存细节。C语言具有高效、灵活和可移植性等特点,因此被广泛应用于系统编程、嵌入式系统开发、游戏开发等领域。 …...
Java基础教程 - 4 流程控制
更好的阅读体验:点这里 ( www.doubibiji.com ) 更好的阅读体验:点这里 ( www.doubibiji.com ) 更好的阅读体验:点这里 ( www.doubibiji.com ) 4 流程控制 4.1 分支结构…...
大厂Java面试题:MyBatis中有几种加载映射器(Mapper.xml)的方式?
大家好,我是王有志。 今天给大家带来的是一道来自京东的 MyBatis 面试题:MyBatis 中有几种加载映射器(Mapper.xml)的方式? 常见加载 MyBatis 映射器的方式有 5 种,可以根据不同的使用方式来进行具体区分&…...
Flutter笔记:Widgets Easier组件库(10)快速处理承若型对话
Flutter笔记 使用Widgets Easier组件库快速处理承若型对话 - 文章信息 - Author: 李俊才 (jcLee95) Visit me at CSDN: https://jclee95.blog.csdn.netMy WebSite:http://thispage.tech/Email: 291148484163.com. Shenzhen ChinaAddress of this article:https://…...
10_Linux中的计划任务
10_Linux中的计划任务 常见计划任务 Linux系统中默认在执行的计划任务 日志文件的轮询:logrotate日志文件分析logwatch任务建立locate数据库建立manpage查询数据库RPM软件日志文件删除缓存与网络有关的分析 仅执行一次的计划任务 atd和at [rootnode4 ~]# systemctl start…...
Google Play开发者账号为什么会被封?如何解决关联账号问题?
Google Play是Google提供的一个应用商店,用户可以在其中下载并安装Android设备上的应用程序、电影、音乐、电子图书等。Google Play是Android平台上较大的应用市场,包含了数百万个应用程序和游戏。但是谷歌对于上架应用的审核越趋严格,开发者…...
(第12天)【leetcode题解】151、反转字符串中的单词
目录 151、反转字符串中的单词题目描述思路代码本题反思 151、反转字符串中的单词 题目描述 给你一个字符串 s ,请你反转字符串中单词的顺序。 单词是由非空格字符组成的字符串。s 中使用至少一个空格将字符串中的单词分隔开。 返回单词顺序颠倒且单词之间用单个…...
如何处理多模态数据噪声不均衡动态?天大等最新《低质量数据的多模态融合》综述
多模态融合致力于整合来自多种模态的信息,目的是实现更准确的预测。在包括自动驾驶和医疗诊断等广泛的场景中,多模态融合已取得显著进展。然而,在低质量数据环境下,多模态融合的可靠性大部分仍未被探索。本文综述了开放多模态融合…...
Autosar NvM配置-手动配置Nvblock及使用-基于ETAS软件
文章目录 前言NvDataInterfaceNvBlockNvM配置SWC配置RTE Mapping使用生成的接口操作NVM总结前言 NVM作为存储协议栈中最顶层的模块,是必须要掌握的。目前项目基本使用MCU带的Dflash模块,使用Fee模拟eeprom。在项目前期阶段,应该充分讨论需要存储的内容,包括应用数据,诊断…...
【c++算法篇】双指针(下)
🔥个人主页:Quitecoder 🔥专栏:算法笔记仓 朋友们大家好啊,本篇文章我们来到算法的双指针的第二部分 目录 1.有效三角形的个数2.查找总价格为目标值的两个商品3.三数之和4.四数之和5.双指针常见场景总结 1.有效三角形…...
微图乐 多种装B截图一键制作工具(仅供娱乐交流)
软件介绍 采用exe进程交互通信。全新UI界面,让界面更加清爽简约。支持zfb、VX、TX、Yin行、Dai款、游戏等图片生成,一键超清原图复制到剪辑板,分享给好友。适用于提高商家信誉度,产品销售额度。装逼娱乐,用微图乐。图…...
基于Springboot的点餐平台
基于SpringbootVue的点餐平台的设计与实现 开发语言:Java数据库:MySQL技术:SpringbootMybatis工具:IDEA、Maven、Navicat 系统展示 用户登录 首页展示 菜品信息 菜品资讯 购物车 后台登录 用户管理 菜品分类管理 菜品信息管理 …...
C# 获取一个字符串中非数字部分?
方法一:使用正则表达式 使用正则表达式可以便捷地匹配并提取出字符串中所有非数字字符。与之前保留数字时的做法相反,这次我们将匹配数字并替换为空字符串,从而留下非数字部分。 using System; using System.Text.RegularExpressions;publi…...
今日总结2024/5/7
今日复习LIS二分优化的使用 P2782 友好城市 确定一边城市排序完后,另外一边满足坐标上升的最大数目即是桥的最大个数 为上升子序列模型 #include <iostream> #include <algorithm> #include <utility> #define x first #define y second cons…...
爬虫学习(3)豆瓣电影
代码 import requests import jsonif __name__ "__main__":url https://movie.douban.com/j/chart/top_list#post请求参数处理(同get请求一致)headers {"User-Agent": Mozilla/5.0 (Windows NT 10.0; Win64; x64) AppleWebKit/53…...
GNU Radio创建FFT、IFFT C++ OOT块
文章目录 前言一、GNU Radio官方FFT弊端二、创建自定义的 C OOT 块1、创建 OOT 模块2、创建 OOT 块3、修改 C 和 CMAKE 文件4、编译及安装 OOT 块 三、测试1、grc 图2、运行结果①、时域波形对比②、频谱图对比 四、资源自取 前言 GNU Radio 自带的 FFT 模块使用起来不是很方便…...
125.两两交换链表中的节点(力扣)
题目描述 代码解决及思路 /*** Definition for singly-linked list.* struct ListNode {* int val;* ListNode *next;* ListNode() : val(0), next(nullptr) {}* ListNode(int x) : val(x), next(nullptr) {}* ListNode(int x, ListNode *next) : val(x), …...
APP精准推送广告是怎么做到的?
你有没有遇到这种情况,刚和家人聊起五一去哪玩,各种软件就刷到各地旅游景点。刚和朋友说到健身计划,转眼间网购平台就给你推荐各种健身用品,这些软件是如何知道我们的需求,难道我们的手机被监听了?从技术上…...
RapidJSON介绍
1.简介 RapidJSON 是一个 C 的 JSON 解析库,由腾讯开源。 支持 SAX 和 DOM 风格的 API,并且可以解析、生成和查询 JSON 数据。RapidJSON 快。它的性能可与strlen() 相比。可支持 SSE2/SSE4.2 加速。RapidJSON 独立。它不依赖于 BOOST 等外部库。它甚至…...
KubeSphere 容器平台高可用:环境搭建与可视化操作指南
Linux_k8s篇 欢迎来到Linux的世界,看笔记好好学多敲多打,每个人都是大神! 题目:KubeSphere 容器平台高可用:环境搭建与可视化操作指南 版本号: 1.0,0 作者: 老王要学习 日期: 2025.06.05 适用环境: Ubuntu22 文档说…...
【Axure高保真原型】引导弹窗
今天和大家中分享引导弹窗的原型模板,载入页面后,会显示引导弹窗,适用于引导用户使用页面,点击完成后,会显示下一个引导弹窗,直至最后一个引导弹窗完成后进入首页。具体效果可以点击下方视频观看或打开下方…...
Linux链表操作全解析
Linux C语言链表深度解析与实战技巧 一、链表基础概念与内核链表优势1.1 为什么使用链表?1.2 Linux 内核链表与用户态链表的区别 二、内核链表结构与宏解析常用宏/函数 三、内核链表的优点四、用户态链表示例五、双向循环链表在内核中的实现优势5.1 插入效率5.2 安全…...
Qt Widget类解析与代码注释
#include "widget.h" #include "ui_widget.h"Widget::Widget(QWidget *parent): QWidget(parent), ui(new Ui::Widget) {ui->setupUi(this); }Widget::~Widget() {delete ui; }//解释这串代码,写上注释 当然可以!这段代码是 Qt …...
DAY 47
三、通道注意力 3.1 通道注意力的定义 # 新增:通道注意力模块(SE模块) class ChannelAttention(nn.Module):"""通道注意力模块(Squeeze-and-Excitation)"""def __init__(self, in_channels, reduction_rat…...
将对透视变换后的图像使用Otsu进行阈值化,来分离黑色和白色像素。这句话中的Otsu是什么意思?
Otsu 是一种自动阈值化方法,用于将图像分割为前景和背景。它通过最小化图像的类内方差或等价地最大化类间方差来选择最佳阈值。这种方法特别适用于图像的二值化处理,能够自动确定一个阈值,将图像中的像素分为黑色和白色两类。 Otsu 方法的原…...
【Java学习笔记】BigInteger 和 BigDecimal 类
BigInteger 和 BigDecimal 类 二者共有的常见方法 方法功能add加subtract减multiply乘divide除 注意点:传参类型必须是类对象 一、BigInteger 1. 作用:适合保存比较大的整型数 2. 使用说明 创建BigInteger对象 传入字符串 3. 代码示例 import j…...
虚拟电厂发展三大趋势:市场化、技术主导、车网互联
市场化:从政策驱动到多元盈利 政策全面赋能 2025年4月,国家发改委、能源局发布《关于加快推进虚拟电厂发展的指导意见》,首次明确虚拟电厂为“独立市场主体”,提出硬性目标:2027年全国调节能力≥2000万千瓦࿰…...
day36-多路IO复用
一、基本概念 (服务器多客户端模型) 定义:单线程或单进程同时监测若干个文件描述符是否可以执行IO操作的能力 作用:应用程序通常需要处理来自多条事件流中的事件,比如我现在用的电脑,需要同时处理键盘鼠标…...
聚六亚甲基单胍盐酸盐市场深度解析:现状、挑战与机遇
根据 QYResearch 发布的市场报告显示,全球市场规模预计在 2031 年达到 9848 万美元,2025 - 2031 年期间年复合增长率(CAGR)为 3.7%。在竞争格局上,市场集中度较高,2024 年全球前十强厂商占据约 74.0% 的市场…...
