vite.config.css.ts 2.5 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556
  1. import type { CSSOptions } from 'vite'
  2. import viewport from 'postcss-px-to-viewport-8-plugin'
  3. import { charsetRemoval, designHeight, designMultiple, designWidth, fontSize, maxWidth, maxWindow, minWidth, minWindow } from './src/design.config'
  4. const config: CSSOptions = {
  5. preprocessorOptions: {
  6. scss: {
  7. additionalData: `
  8. $vmDesignWidth: ${designWidth};
  9. $vmDesignHeight: ${designHeight};
  10. $vmDesignMultiple: ${designMultiple};
  11. $vmMinWidth: ${minWidth};
  12. $vmMinWindow: ${minWindow};
  13. $vmMaxWidth: ${maxWidth};
  14. $vmMaxWindow: ${maxWindow};
  15. $vmFontSize: ${fontSize};
  16. `,
  17. api: 'modern-compiler',
  18. // 忽略scss global-builtin, import 提示3.0将删除的警告
  19. silenceDeprecations: ['global-builtin', 'import'],
  20. },
  21. },
  22. postcss: {
  23. plugins: [
  24. /**
  25. * 将 px 单位转换为视图单位(vw, vh, vmin, vmax)的 PostCSS 插件
  26. * @see https://github.com/lkxian888/postcss-px-to-viewport-8-plugin#readme
  27. */
  28. viewport({
  29. unitToConvert: 'px', // 要转化的单位
  30. viewportWidth: (file: string) => {
  31. // 字号 * 100
  32. let viewportWidth = fontSize * 100
  33. if (file.includes('vant')) {
  34. viewportWidth = fontSize * (375 / designWidth * 100)
  35. }
  36. return viewportWidth
  37. }, // UI设计稿的宽度
  38. unitPrecision: 6, // 转换后的精度,即小数点位数
  39. propList: ['*'], // 指定可以转换的css属性,*代表全部css属性
  40. viewportUnit: 'rem', // 指定需要转换成的视窗单位,默认vw
  41. fontViewportUnit: 'rem', // 指定字体需要转换成的视窗单位,默认vw
  42. selectorBlackList: ['svg-text'], // 指定不转换为视窗单位的类名
  43. minPixelValue: 1, // 默认值1,小于或等于1px则不进行转换
  44. mediaQuery: true, // 是否在媒体查询的css代码中也进行转换,默认false
  45. replace: true, // 是否转换后直接更换属性值
  46. // exclude: [/node_modules/], // 设置忽略文件,用正则做目录名匹配
  47. landscape: false, // 是否处理横屏情况
  48. }),
  49. charsetRemoval(),
  50. ],
  51. },
  52. }
  53. export default config