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 设定字体大小。

注意事项

  1. 每次修改postcssConfig.ts配置项的时候需要重新启动项目,因为你触碰了nuxt.config.ts配置。
  2. 如果你刚开始并没有采用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需要转换的单位,默认为 pxstringpx
viewportWidth设计稿的视口宽度,如传入函数,函数的参数为当前处理的文件路径,函数返回 undefind 跳过转换number | Function320
unitPrecision单位转换后保留的精度number5
propList能转化为 vw 的属性列表string[]['*']
viewportUnit希望使用的视口单位stringvw
fontViewportUnit字体使用的视口单位stringvw
selectorBlackList需要忽略的 CSS 选择器,不会转为视口单位,使用原有的 px 等单位string[][]
minPixelValue设置最小的转换数值,如果为 1 的话,只有大于 1 的值会被转换number1
mediaQuery媒体查询里的单位是否需要转换单位booleanfalse
replace是否直接更换属性值,而不添加备用属性booleantrue
landscape是否添加根据 landscapeWidth 生成的媒体查询条件 @media (orientation: landscape)booleanfalse
landscapeUnit横屏时使用的单位stringvw
landscapeWidth横屏时使用的视口宽度,,如传入函数,函数的参数为当前处理的文件路径,函数返回 undefind 跳过转换number568
exclude忽略某些文件夹下的文件或特定文件,例如 node_modules 下的文件,如果值是一个正则表达式,那么匹配这个正则的文件会被忽略,如果传入的值是一个数组,那么数组里的值必须为正则Regexpundefined
include需要转换的文件,例如只转换 'src/mobile' 下的文件 (include: /\/src\/mobile\//),如果值是一个正则表达式,将包含匹配的文件,否则将排除该文件, 如果传入的值是一个数组,那么数组里的值必须为正则Regexpundefined

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/832899.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

六西格玛项目的核心要素:理论学习、实践应用与项目经验

许多朋友担心,没有项目经验是否就意味着无法考取六西格玛证书。针对这一疑问,张驰咨询为大家详细解答。 首先,需要明确的是,六西格玛项目不仅仅是一种管理工具或方法,更是一种追求卓越、持续改进的思维方式。它强调通…

git与gitlab

目录 gitlab 下载与安装 重置管理员密码 gitlab命令 git远程gitlab相关命令 认证 补充 git git 分布式版本控制 安装 git的四个区域与文件的四个状态 使用git 常用命令 git 分布式管理系统 gitlab 企业私有库 github 公网共享库,全球…

PHP基础教程

🐌博主主页:🐌​倔强的大蜗牛🐌​ 📚专栏分类:PHP 📚参考教程:菜鸟\编程网❤️感谢大家点赞👍收藏⭐评论✍️ 目录 一、PHP语法 基本的 PHP 语法 PHP 注释 PHP空白不敏…

环保访谈|浙江双视专注红外机器视觉及智能化应用,保障安全生产

近期,中联环保圈希姐采访了浙江双视科技股份有限公司环保行业销售总监孙波,深入了解了双视科技的发展历程、产品和解决方案、合作流程、核心竞争力以及未来规划。 双视于2014年创立,专注于红外机器视觉、人工智能技术与应用开发,…

JuiceFS v1.2-beta1,Gateway 升级,多用户场景权限管理更灵活

JuiceFS v1.2-beta1 今天正式发布。在这个版本中,除了进行了大量使用体验优化和 bug 修复外,新增三个特性: Gateway 功能扩展:新增了“身份和访问管理(Identity and Access Management,IAM)” 与…

系统如何做好安全加固?

一、Windows系统 Windows系统出厂时,微软为了兼容性,默认并未对系统安全做严格的限制,因此还需要做一些基本的安全加固,方可防止黑客入侵。 1、系统补丁更新 为什么要更新系统补丁?很多人感觉漏洞更新没必要&#x…

TC6291C 是一款电流模式升压型DC-DC转换器芯片

一般概述 TC6291C是一款电流模式升压型DC-DC转换器。其脉宽调制电路,内置0.2Q功率场效应管使这个调节器具有高功率效率。内部补偿网络也减少了多达6个的外部元件。误差信号放大器的同相输入端连接到0.6V精密基准电压,内部软启动功能可以减小瞬间突…

划重点!PMP报考条件、报考步骤、考试内容、适合人群

参加PMP认证的好处,可以从几个方面来认识: 一、参加PMP认证与考试的过程,同时是一个系统学习和巩固项目管理知识的过程 二、参加PMP认证,您可以获得由PMI颁发的PMP证书 而拥有PMP认证表示你已经成为一个项目管理方面的专业人员…

Azide-PEG-Azide,82055-94-5可以用于制备抗体、蛋白质、多肽等生物分子的标记物

【试剂详情】 英文名称 Azide-PEG-Azide,N3-PEG-N3 中文名称 叠氮-聚乙二醇-叠氮,聚氧乙烯二叠氮化物 CAS号 82055-94-5 外观性状 由分子量决定,粘稠液体或者固体。 分子量 0.4k,0.6k,1k,2k&#…

基于springboot+vue+Mysql的影城管理系统

开发语言:Java框架:springbootJDK版本:JDK1.8服务器:tomcat7数据库:mysql 5.7(一定要5.7版本)数据库工具:Navicat11开发软件:eclipse/myeclipse/ideaMaven包:…

Ansible简介版

目录 架构 环境部署 一、Ansible安装部署 1.yum安装Ansible 2.修改主机清单文件 3.配置密钥对验证 4.ansible-doc 5.看被控主机 二、常用模块 1.Command模块 2.Shell模块 3.Cron模块 1.添加 2.删除 4.User模块 5.Group模块 1.创建组 ​编辑 ​编辑 ​编辑…

java+jsp+Oracle+Tomcat 记账管理系统论文(完整版)

⬇️⬇️⬇️⬇️⬇️⬇️⬇️⬇️⬇️⬇️⬇️⬇️⬇️⬇️⬇️⬇️⬇️⬇️⬇️⬇️⬇️⬇️⬇️⬇️⬇️⬇️⬇️⬇️⬇️⬇️⬇️ ➡️点击免费下载全套资料:源码、数据库、部署教程、论文、答辩ppt一条龙服务 ➡️有部署问题可私信联系 ⬆️⬆️⬆️​​​​​​​⬆️…

基于POSIX标准库的读者-写者问题的简单实现

文章目录 实验要求分析保证读写、写写互斥保证多个读者同时进行读操作 读者优先实例代码分析 写者优先示例代码分析 实验要求 创建一个控制台进程,此进程包含n个线程。用这n个线程来表示n个读者或写者。每个线程按相应测试数据文件的要求进行读写操作。用信号量机制…

贪吃蛇游戏(C语言实现)

目录 游戏效果展示文件代码的展示test.cSnake.cSnake.h 下一个坐标不是食物 游戏效果展示 QQ录屏20240507163633 文件 代码的展示 test.c #define _CRT_SECURE_NO_WARNINGS#include<locale.h> //设置本地化 #include"Snake.h"//游戏的测试逻辑 void test() {…

【how2j Vue部分】两种在Vue的Ajax框架——fetch axios

fetch.js 和 axios.js 都是 Vue 中比较常见的两种ajax框架 1. fetch.js 一般说来 Vue 不会直接使用原生的 Ajax 而是使用 ajax 框架。 而 fetch.js 就是眼下比较流行的一种 ajax 框架 1. 准备 json数据&#xff1a;var url "https://gitee.com/api/v5/users/liyangyf&…

STM32F407VET6 学习笔记1:GPIO引脚认识分类与开发板原理图

今日学习STM32F407VET6 &#xff0c;首先从基本原理图、引脚方面开始做个初步理解并整理&#xff1a; 这里使用的学习开发板是在嘉立创购买的 立创梁山派天空星&#xff0c;芯片是 STM32F407VET6 主要对这个芯片的引脚做一些归纳认识、对开发学习板原理图设计进行认识理解:最…

新的字符设备注册方式和自动创建节点

文章目录 前言一、设备号的申请1.自动申请设备号2.用户指定设备号 二、获取设备号的程序格式1.格式 三、字符设备注册1.新的字符设备注册方法 四、节点的自动创建1.mdev机制2.mdev机制实现流程①创建一个类②创建一个设备 五、总结流程六、文件私有数据 前言 &#x1f4a6; re…

食品饮料-冲饮市场线上发展现状:香飘飘品牌监控数据分析

近期&#xff0c;老国货品牌香飘飘在国内备受关注&#xff0c;起因是某网友在日本华人超市内看到香飘飘Meco果汁茶产品包装统一增加了几组“海洋不是日本的下水道”、“请日本政客豪饮核污水”、“地球可以没有日本但不能没有海洋”等中日双语标语&#xff0c;正大光明讽刺日本…

茶多酚复合纳米纤维膜

茶多酚复合纳米纤维膜是一种结合了茶多酚与纳米纤维技术的创新材料。茶多酚作为茶叶中多酚类物质的总称&#xff0c;具有抗氧化、抗辐射、抗*等多种药理作用&#xff0c;是一种非常有益的天然物质。而纳米纤维膜则因其超细纤维结构、高比表面积和高孔隙率等特性&#xff0c;在过…

(五)JVM实战——JVM性能调优与监控

JVM调优案例的场景 为什么要调优&#xff1a;防止或者解决jvm虚拟机中的OOM问题&#xff1b;减少FullGC出现的频率&#xff0c;解决系统运行卡、慢问题JVM调优案例的四个方面 OOM(堆溢出)&#xff1a;java heap spaceOOM(元空间溢出)&#xff1a;MetaspaceOOM(GC overhead lim…