| 1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556 |
- import type { CSSOptions } from 'vite'
- import viewport from 'postcss-px-to-viewport-8-plugin'
- import { charsetRemoval, designHeight, designMultiple, designWidth, fontSize, maxWidth, maxWindow, minWidth, minWindow } from './src/design.config'
- const config: CSSOptions = {
- preprocessorOptions: {
- scss: {
- additionalData: `
- $vmDesignWidth: ${designWidth};
- $vmDesignHeight: ${designHeight};
- $vmDesignMultiple: ${designMultiple};
- $vmMinWidth: ${minWidth};
- $vmMinWindow: ${minWindow};
- $vmMaxWidth: ${maxWidth};
- $vmMaxWindow: ${maxWindow};
- $vmFontSize: ${fontSize};
- `,
- api: 'modern-compiler',
- // 忽略scss global-builtin, import 提示3.0将删除的警告
- silenceDeprecations: ['global-builtin', 'import'],
- },
- },
- postcss: {
- plugins: [
- /**
- * 将 px 单位转换为视图单位(vw, vh, vmin, vmax)的 PostCSS 插件
- * @see https://github.com/lkxian888/postcss-px-to-viewport-8-plugin#readme
- */
- viewport({
- unitToConvert: 'px', // 要转化的单位
- viewportWidth: (file: string) => {
- // 字号 * 100
- let viewportWidth = fontSize * 100
- if (file.includes('vant')) {
- viewportWidth = fontSize * (375 / designWidth * 100)
- }
- return viewportWidth
- }, // UI设计稿的宽度
- unitPrecision: 6, // 转换后的精度,即小数点位数
- propList: ['*'], // 指定可以转换的css属性,*代表全部css属性
- viewportUnit: 'rem', // 指定需要转换成的视窗单位,默认vw
- fontViewportUnit: 'rem', // 指定字体需要转换成的视窗单位,默认vw
- selectorBlackList: ['svg-text'], // 指定不转换为视窗单位的类名
- minPixelValue: 1, // 默认值1,小于或等于1px则不进行转换
- mediaQuery: true, // 是否在媒体查询的css代码中也进行转换,默认false
- replace: true, // 是否转换后直接更换属性值
- // exclude: [/node_modules/], // 设置忽略文件,用正则做目录名匹配
- landscape: false, // 是否处理横屏情况
- }),
- charsetRemoval(),
- ],
- },
- }
- export default config
|