实现方法:通过 postcss-px-to-viewport 来自动将我们开发时的px单位计算转换为vw视口单位,完成响应式布局 。
npm安装
npm install postcss-px-to-viewport -S
yarn安装
yarn add postcss-px-to-viewport -S
module.exports = { plugins: { 'postcss-px-to-viewport': { unitToConvert: 'px', // 需要转换的单位,默认为"px" viewportWidth: 1920, // ui设计稿的视口宽度 unitPrecision: 5, // 单位转换后保留的精度 propList: ['*'], // 能转化为vw的属性列表,不需要转换的css样式属性可以写在propList['*']里面,在前面加上!号即可,比如propList['*','!width'],这表示css所有的属性都可以单位转换,除了width不转换。 viewportUnit: 'vw', // 希望使用的视口单位 fontViewportUnit: 'vw', // 字体使用的视口单位 selectorBlackList: [], // 需要忽略的CSS选择器,不会转为视口单位,使用原有的px等单位,比如selectorBlackList: ['box'],box这个类名下使用的所有css属性都不会被转换单位。 minPixelValue: 1, // 设置最小的转换数值,如果为1的话,只有大于1的值会被转换 mediaQuery: false, // 媒体查询里的单位是否需要转换单位 replace: true, // 是否直接更换属性值,而不添加备用属性 exclude: undefined, // 忽略某些文件夹下的文件或特定文件,例如 'node_modules' 下的文件 include: undefined, // 如果设置了include,那将只有匹配到的文件才会被转换 landscape: false, // 是否添加根据 landscapeWidth 生成的媒体查询条件 @media (orientation: landscape) landscapeUnit: 'vw', // 横屏时使用的单位 landscapeWidth: 1920 // 横屏时使用的视口宽度 } } }
'运行
const path = require('path') module.exports = ({ file }) => { const designWidth = file.dirname.includes( path.join('node_modules', 'ant-design-vue') ) ? 375 : 750 return { plugins: { autoprefixer: {}, // 用来给不同的浏览器自动添加相应前缀,如-webkit-,-moz-等等 'postcss-px-to-viewport': { unitToConvert: 'px', // 要转化的单位 viewportWidth: designWidth, // UI设计稿的宽度 unitPrecision: 6, // 转换后的精度,即小数点位数 propList: ['*'], // 指定转换的css属性的单位,*代表全部css属性的单位都进行转换 viewportUnit: 'vw', // 指定需要转换成的视窗单位,默认vw fontViewportUnit: 'vw', // 指定字体需要转换成的视窗单位,默认vw selectorBlackList: [], // 指定不转换为视窗单位的类名, minPixelValue: 1, // 默认值1,小于或等于1px则不进行转换 mediaQuery: true, // 是否在媒体查询的css代码中也进行转换,默认false exclude: [], // 设置忽略文件,用正则做目录名匹配 landscape: false, // 是否处理横屏情况 // replace: true, // 是否转换后直接更换属性值 }, }, } }
'运行
配置好文件以后,重启项目就行,也可以不用重启,编译一下就行,可以测试一下,用一张全屏图片,给图片设置宽高,缩小放大浏览器窗口,图片跟着视口变化就成功了。
仔细看上面的配置信息,需要的进行配置。