uno.config.ts 3.0 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495
  1. import type {
  2. Preset,
  3. } from 'unocss'
  4. // https://www.npmjs.com/package/@uni-helper/unocss-preset-uni
  5. import { presetUni } from '@uni-helper/unocss-preset-uni'
  6. // @see https://unocss.dev/presets/legacy-compat
  7. import { presetLegacyCompat } from '@unocss/preset-legacy-compat'
  8. import {
  9. defineConfig,
  10. presetIcons,
  11. transformerDirectives,
  12. transformerVariantGroup,
  13. } from 'unocss'
  14. export default defineConfig({
  15. presets: [
  16. presetUni({
  17. attributify: false,
  18. }),
  19. presetIcons({
  20. scale: 1.2,
  21. warn: true,
  22. extraProperties: {
  23. 'display': 'inline-block',
  24. 'vertical-align': 'middle',
  25. },
  26. }),
  27. // TODO: check 是否会有别的影响
  28. // 处理低端安卓机的样式问题
  29. // 将颜色函数 (rgb()和hsl()) 从空格分隔转换为逗号分隔,更好的兼容性app端,example:
  30. // `rgb(255 0 0)` -> `rgb(255, 0, 0)`
  31. // `rgba(255 0 0 / 0.5)` -> `rgba(255, 0, 0, 0.5)`
  32. presetLegacyCompat({
  33. commaStyleColorFunction: true,
  34. }) as Preset,
  35. ],
  36. transformers: [
  37. // 启用指令功能:主要用于支持 @apply、@screen 和 theme() 等 CSS 指令
  38. transformerDirectives(),
  39. // 启用 () 分组功能
  40. // 支持css class组合,eg: `<div class="hover:(bg-gray-400 font-medium) font-(light mono)">测试 unocss</div>`
  41. transformerVariantGroup(),
  42. ],
  43. shortcuts: [
  44. {
  45. center: 'flex justify-center items-center',
  46. },
  47. ],
  48. // 动态图标需要在这里配置,或者写在vue页面中注释掉
  49. safelist: ['i-carbon-code', 'i-carbon-home', 'i-carbon-user'],
  50. rules: [
  51. [
  52. 'p-safe',
  53. {
  54. padding:
  55. 'env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left)',
  56. },
  57. ],
  58. ['pt-safe', { 'padding-top': 'env(safe-area-inset-top)' }],
  59. ['pb-safe', { 'padding-bottom': 'env(safe-area-inset-bottom)' }],
  60. ],
  61. theme: {
  62. colors: {
  63. /** 主题色,用法如: text-primary */
  64. primary: 'var(--wot-color-theme,#0957DE)',
  65. },
  66. fontSize: {
  67. /** 提供更小号的字体,用法如:text-2xs */
  68. '2xs': ['20rpx', '28rpx'],
  69. '3xs': ['18rpx', '26rpx'],
  70. },
  71. },
  72. content: {
  73. /**
  74. * 解决小程序报错 `./app.wxss(78:2814): unexpected unexpected at pos 5198`
  75. * 为什么同时使用include和exclude?虽然看起来多余,但同时配置两者是一种常见的 `防御性编程` 做法。
  76. 1. 结构变化保障 : 如果未来项目结构发生变化,某些排除目录可能被移动到包含路径下,exclude配置可以确保它们仍被排除
  77. 2. 明确性 : 明确列出要排除的目录使配置意图更加清晰
  78. 3. 性能优化 : 避免处理不必要的文件,提高构建性能
  79. 4. 防止冲突 : 排除第三方库和构建输出目录,避免潜在的CSS冲突
  80. */
  81. pipeline: {
  82. exclude: [
  83. 'node_modules/**/*',
  84. 'public/**/*',
  85. 'dist/**/*',
  86. ],
  87. include: [
  88. './src/**/*',
  89. ],
  90. },
  91. },
  92. })