1-07 React配置postcss-px-to-viewport

React配置postcss-px-to-viewport

移动端适配

  1. 安装依赖:在项目根目录下运行以下命令安装所需的依赖包:
sh 复制代码
npm install postcss-px-to-viewport --save-dev
  1. 配置代码
js 复制代码
const path = require('path');

module.exports = {
	webpack: {
		alias: {
			'@': path.resolve(__dirname, 'src'),
		},
	},

	style: {
		postcss: {
			mode: 'exclude',
			loaderOptions: {
				postcssOptions: {
					ident: 'postcss',
					plugins: [
						[
							'postcss-px-to-viewport',
							{
								unitToConvert: 'px', // 要转化的单位
								viewportWidth: 375, // UI设计稿的宽度
								viewportUnit: 'vw', // 指定需要转换成的视窗单位,建议使用 rem
								fontViewportUnit: 'vw', // 字体使用的视口单位
								unitPrecision: 13, // 指定`px`转换为视窗单位值的小数后 x位数
								// propList: 当有些属性的单位我们不希望转换的时候,可以添加在数组后面,并在前面加上!号,如propList: ["*","!letter-spacing"],这表示:所有css属性的属性的单位都进行转化,除了letter-spacing的
								propList: ['*'], // 指定转换的css属性的单位,*代表全部css属性的单位都进行转换
								// 转换的黑名单,在黑名单里面的我们可以写入字符串,只要类名包含有这个字符串,就不会被匹配。比如selectorBlackList: ['wrap'],它表示形如wrap,my-wrap,wrapper这样的类名的单位,都不会被转换
								selectorBlackList: ['ignore'], // 指定不转换为视窗单位的类名,
								minPixelValue: 1, // 默认值1,小于或等于1px则不进行转换
								mediaQuery: true, // 是否在媒体查询的css代码中也进行转换,默认false
								replace: true, // 是否转换后直接更换属性值
								exclude: [/node_modules/], // 设置忽略文件,用正则做目录名匹配
								landscape: false, // 是否处理横屏情况
							},
						],
					],
				},
			},
		},
	},
};
  1. 重新启动开发服务器:如果你的开发服务器正在运行,请重新启动它以应用新的配置。

之后当我们写px时会自动转换成vm单位

相关推荐
ohyeah9 分钟前
用原生 JS 手写一个“就地编辑”组件:EditInPlace 的 OOP 实践
前端·javascript
毕设源码-邱学长15 分钟前
【开题答辩全过程】以 基于JavaScript的图书销售网站为例,包含答辩的问题和答案
开发语言·javascript·ecmascript
timeweaver16 分钟前
React Server Components 的致命漏洞CVE-2025-55182
前端·安全
重铸码农荣光18 分钟前
深入理解 JavaScript 中的 this:一场关于作用域、调用方式与设计哲学的思辨
前端·javascript
新晨43718 分钟前
跨域是服务器拒绝请求还是浏览器去拒绝的请求?
前端·浏览器
珑墨23 分钟前
【包管理器】pnpm、npm、cnpm、yarn 深度对比
前端·javascript·npm·node.js
老王熬夜敲代码31 分钟前
泛型编程的差异抽象思想
开发语言·c++·笔记
草字31 分钟前
uniapp 滚动到表单的某个位置,表单验证失败时。
前端·javascript·uni-app
学到头秃的suhian31 分钟前
Spring使用三级缓存解决循环依赖问题
前端·spring·缓存
CXH72833 分钟前
架构师的登山之路|第十二站:服务网格 Istio——未来的标配,还是复杂过头?
前端·javascript·istio