uniapp +vue3+ts+tailwindcss 开发搭建兼容小程序版本

1、创建uniapp cli版本

uniapp官网 环境安装

  1. 命令行使用以下命令
//使用正式版(对应HBuilderX最新正式版)
vue create -p dcloudio/uni-preset-vue my-project

//使用alpha版(对应HBuilderX最新alpha版)
vue create -p dcloudio/uni-preset-vue#alpha my-alpha-project
  1. 选择默认模板 typescript 安装
    在这里插入图片描述
    到这一步 完成 uniapp+vue3+ts的搭建

2、安装tailwindcss

我使用的是 兼容版本的
PostCSS 7 兼容性版本

npm install tailwindcss@npm:@tailwindcss/postcss7-compat @tailwindcss/postcss7-compat postcss@^7 autoprefixer@^9

生成 默认配置文件 tailwind.config.js 和 postcss.config.js

npx tailwindcss init -p

3.安装scss

直接安装最新版有问题 我是通过 package.json 写好安装依赖 然后 yarn install 安装的

"sass": "^1.32.8",
"sass-loader": "10.1.1",

4. 兼容小程序

兼容小程序可以使用第三方写好的预设 也可以自己改环境配置
默认环境配置文件在 node_modules/stubs/defaultConfig.stub目录下;
主要是 把/ :等class重命名为其他微信小程序允许的字符 如:sm: hover: w-1/2 都是不支持的

第三方预设 tailwindcss-miniprogram-preset
参考文章 tailwindcss 小程序定制化之旅

yarn add  tailwindcss-miniprogram-preset
npm  install  tailwindcss-miniprogram-preset  -s

postcss.config.js

const path = require('path')
module.exports = {
    
    
  parser: require('postcss-comment'),
  plugins: [
    require('postcss-import')({
    
    
      resolve(id, basedir, importOptions) {
    
    
        if (id.startsWith('~@/')) {
    
    
          return path.resolve(process.env.UNI_INPUT_DIR, id.substr(3))
        } else if (id.startsWith('@/')) {
    
    
          return path.resolve(process.env.UNI_INPUT_DIR, id.substr(2))
        } else if (id.startsWith('/') && !id.startsWith('//')) {
    
    
          return path.resolve(process.env.UNI_INPUT_DIR, id.substr(1))
        }
        return id
      }
    }),

    require('@dcloudio/vue-cli-plugin-uni/packages/postcss'),
    require("tailwindcss")({
    
     config: "./tailwind.config.js" }),
    /* ******* 引入tailwindcss ******* */
    // // 根据平台差异进行不同的样式处理
    ...(
      process.env.UNI_PLATFORM !== "h5"
        ?
        [
          // 使用postcss-class-name 包将小程序不支持的类名写法转换为支持的类名,如:"hover:xxx"
          require("postcss-class-rename")({
    
    
            // "\\\\:": "--",
            // "\\\\/": "--",
            // "\\\\.": "--",
            // ".:": "--",
            // "\\\*": "--",

            // 引用  tailwindcss-miniprogram-preset 预设时
            '\\\\:': '--',
            '\\\\/': '_',
          })
        ]
        : [
          require("autoprefixer")({
    
    
            remove: true,
          }),
        ]
    ),


  ]
}

如果没有 postcss-class-rename 就安装

yarn add  postcss-class-rename
npm  install   postcss-class-rename  -s

tailwind.config.js

const miniprogramPreset = require('./tailwindcss-miniprogram-preset/src/index.js')  //去除自适应和无用插件 定制化兼容小程序的牺牲
// const miniprogramPreset = require('tailwindcss-miniprogram-preset')  //去除自适应和无用插件 定制化兼容小程序的牺牲
const colors = require('tailwindcss/colors')
/** @type {import('@types/tailwindcss/tailwind-config').TailwindConfig} */
module.exports = {
    
    
  purge: miniprogramPreset.purge.content,
  presets: [miniprogramPreset],
}

下图为第三方预设的配置 输入时 / 使用 -div- 代替了 .使用-dot-代替了 使用 包含/与.的tailwindcss class会被 postcss.config.js 文件设置的重命名 拆分而失效 使用代替字符则生效
在这里插入图片描述
第三方预设 rem被rpx替换 rootValue 标识 1rem 对应 32rpx
在这里插入图片描述
如果不使用第三方预设 可以在 tailwind.config.js 文件 直接配置 theme属性 使用默认环境配置把需要的部分 更改即可,下方为修改theme属性 方式的tailwind.config.js 文件

module.exports = {
    
    
  // Tree-shake unused styles in production build
  purge: ['./src/**/*.{vue,js,ts,jsx,tsx,html}'],
  // purge: [],
  darkMode: false, // or 'media' or 'class'
  theme: {
    
    
    screens: {
    
    
      sm: '640px',
      md: '768px',
      lg: '1024px',
      xl: '1280px',
      '2xl': '1536px',
    },
    colors: {
    
    
      transparent: 'transparent',
      current: 'currentColor',

      black: '#000',
      white: '#fff',

      gray: colors.gray,
      red: colors.red,
      yellow: colors.amber,
      green: colors.emerald,
      blue: colors.blue,
      purple: colors.violet,
      pink: colors.pink,
    },
    spacing: {
    
    
      px: '1px',
      rpx: '1rpx',
      0: '0',
      0.5: '0.125rem',
      1: '0.25rem',
      1.5: '0.375rem',
      2: '0.5rem',
      2.5: '0.625rem',
      3: '0.75rem',
      3.5: '0.875rem',
      4: '1rem',
      5: '1.25rem',
      6: '1.5rem',
      7: '1.75rem',
      8: '2rem',
      9: '2.25rem',
      10: '2.5rem',
      12: '3rem',
      14: '3.5rem',
      16: '4rem',
      20: '5rem',
      24: '6rem',
      28: '7rem',
      32: '8rem',
      36: '9rem',
      40: '10rem',
      44: '11rem',
      48: '12rem',
      52: '13rem',
      56: '14rem',
      60: '15rem',
      64: '16rem',
      72: '18rem',
      80: '20rem',
      96: '24rem',
    },
    backgroundColor: (theme) => theme('colors'),
    backgroundImage: {
    
    
      none: 'none',
      'gradient-to-t': 'linear-gradient(to top, var(--gradient-color-stops))',
      'gradient-to-tr': 'linear-gradient(to top right, var(--gradient-color-stops))',
      'gradient-to-r': 'linear-gradient(to right, var(--gradient-color-stops))',
      'gradient-to-br': 'linear-gradient(to bottom right, var(--gradient-color-stops))',
      'gradient-to-b': 'linear-gradient(to bottom, var(--gradient-color-stops))',
      'gradient-to-bl': 'linear-gradient(to bottom left, var(--gradient-color-stops))',
      'gradient-to-l': 'linear-gradient(to left, var(--gradient-color-stops))',
      'gradient-to-tl': 'linear-gradient(to top left, var(--gradient-color-stops))',
    },
    gradientColorStops: (theme) => theme('colors'),
    backgroundOpacity: (theme) => theme('opacity'),
    backgroundPosition: {
    
    
      bottom: 'bottom',
      center: 'center',
      left: 'left',
      'left-bottom': 'left bottom',
      'left-top': 'left top',
      right: 'right',
      'right-bottom': 'right bottom',
      'right-top': 'right top',
      top: 'top',
    },
    backgroundSize: {
    
    
      auto: 'auto',
      cover: 'cover',
      contain: 'contain',
    },
    borderColor: (theme) => ({
    
    
      ...theme('colors'),
      DEFAULT: theme('colors.gray.200', 'currentColor'),
    }),
    borderOpacity: (theme) => theme('opacity'),
    borderRadius: {
    
    
      none: '0',
      sm: '0.125rem',
      DEFAULT: '0.25rem',
      md: '0.375rem',
      lg: '0.5rem',
      xl: '0.75rem',
      '2xl': '1rem',
      '3xl': '1.5rem',
      full: '9999px',
    },
    borderWidth: {
    
    
      DEFAULT: '1rpx',
      0: '0',
      2: '2rpx',
      4: '4rpx',
      8: '8rpx',
    },
    boxShadow: {
    
    
      xs: '0 0 0 1rpx rgba(0, 0, 0, 0.05)',
      sm: '0 1rpx 2rpx 0 rgba(0, 0, 0, 0.05)',
      DEFAULT: '0 1rpx 3rpx 0 rgba(0, 0, 0, 0.1), 0 1rpx 2rpx 0 rgba(0, 0, 0, 0.06)',
      md: '0 4rpx 6rpx -1rpx rgba(0, 0, 0, 0.1), 0 2rpx 4rpx -1rpx rgba(0, 0, 0, 0.06)',
      lg: '0 10rpx 15rpx -3rpx rgba(0, 0, 0, 0.1), 0 4rpx 6rpx -2rpx rgba(0, 0, 0, 0.05)',
      xl: '0 20rpx 25rpx -5rpx rgba(0, 0, 0, 0.1), 0 10rpx 10rpx -5rpx rgba(0, 0, 0, 0.04)',
      '2xl': '0 25rpx 50rpx -12rpx rgba(0, 0, 0, 0.25)',
      inner: 'inset 0 2rpx 4rpx 0 rgba(0, 0, 0, 0.06)',
      outline: '0 0 0 3rpx rgba(66, 153, 225, 0.5)',
      none: 'none',
    },
    container: {
    
    },
    cursor: {
    
    
      auto: 'auto',
      default: 'default',
      pointer: 'pointer',
      wait: 'wait',
      text: 'text',
      move: 'move',
      'not-allowed': 'not-allowed',
    },
    divideColor: (theme) => theme('borderColor'),
    divideOpacity: (theme) => theme('borderOpacity'),
    divideWidth: (theme) => theme('borderWidth'),
    fill: {
    
    
      current: 'currentColor',
    },
    flex: {
    
    
      1: '1 1 0%',
      auto: '1 1 auto',
      initial: '0 1 auto',
      none: 'none',
    },
    flexGrow: {
    
    
      0: '0',
      DEFAULT: '1',
    },
    flexShrink: {
    
    
      0: '0',
      DEFAULT: '1',
    },
    fontFamily: {
    
    
      sans: [
        'ui-sans-serif',
        'system-ui',
        '-apple-system',
        'BlinkMacSystemFont',
        '"Segoe UI"',
        'Roboto',
        '"Helvetica Neue"',
        'Arial',
        '"Noto Sans"',
        'sans-serif',
        '"Apple Color Emoji"',
        '"Segoe UI Emoji"',
        '"Segoe UI Symbol"',
        '"Noto Color Emoji"',
      ],
      serif: ['ui-serif', 'Georgia', 'Cambria', '"Times New Roman"', 'Times', 'serif'],
      mono: [
        'ui-monospace',
        'SFMono-Regular',
        'Menlo',
        'Monaco',
        'Consolas',
        '"Liberation Mono"',
        '"Courier New"',
        'monospace',
      ],
    },
    fontSize: {
    
    
      xs: ['0.75rem', {
    
     lineHeight: '1rem' }],
      sm: ['0.875rem', {
    
     lineHeight: '1.25rem' }],
      base: ['1rem', {
    
     lineHeight: '1.5rem' }],
      lg: ['1.125rem', {
    
     lineHeight: '1.75rem' }],
      xl: ['1.25rem', {
    
     lineHeight: '1.75rem' }],
      '2xl': ['1.5rem', {
    
     lineHeight: '2rem' }],
      '3xl': ['1.875rem', {
    
     lineHeight: '2.25rem' }],
      '4xl': ['2.25rem', {
    
     lineHeight: '2.5rem' }],
      '5xl': ['3rem', {
    
     lineHeight: '1' }],
      '6xl': ['3.75rem', {
    
     lineHeight: '1' }],
      '7xl': ['4.5rem', {
    
     lineHeight: '1' }],
      '8xl': ['6rem', {
    
     lineHeight: '1' }],
      '9xl': ['8rem', {
    
     lineHeight: '1' }],
    },
    fontWeight: {
    
    
      thin: '100',
      extralight: '200',
      light: '300',
      normal: '400',
      medium: '500',
      semibold: '600',
      bold: '700',
      extrabold: '800',
      black: '900',
    },
    height: (theme) => ({
    
    
      auto: 'auto',
      ...theme('spacing'),
      full: '100%',
      screen: '100vh',
    }),
    inset: (theme, {
     
      negative }) => ({
    
    
      auto: 'auto',
      ...theme('spacing'),
      ...negative(theme('spacing')),
      '1_2': '50%',
      '1_3': '33.333333%',
      '2_3': '66.666667%',
      '1_4': '25%',
      '2_4': '50%',
      '3_4': '75%',
      full: '100%',
      '-1_2': '-50%',
      '-1_3': '-33.333333%',
      '-2_3': '-66.666667%',
      '-1_4': '-25%',
      '-2_4': '-50%',
      '-3_4': '-75%',
      '-full': '-100%',
    }),
    letterSpacing: {
    
    
      tighter: '-0.05em',
      tight: '-0.025em',
      normal: '0',
      wide: '0.025em',
      wider: '0.05em',
      widest: '0.1em',
    },
    lineHeight: {
    
    
      none: '1',
      tight: '1.25',
      snug: '1.375',
      normal: '1.5',
      relaxed: '1.625',
      loose: '2',
      3: '.75rem',
      4: '1rem',
      5: '1.25rem',
      6: '1.5rem',
      7: '1.75rem',
      8: '2rem',
      9: '2.25rem',
      10: '2.5rem',
    },
    listStyleType: {
    
    
      none: 'none',
      disc: 'disc',
      decimal: 'decimal',
    },
    margin: (theme, {
     
      negative }) => ({
    
    
      auto: 'auto',
      ...theme('spacing'),
      ...negative(theme('spacing')),
    }),
    maxHeight: (theme) => ({
    
    
      ...theme('spacing'),
      full: '100%',
      screen: '100vh',
    }),
    maxWidth: (theme, {
     
      breakpoints }) => ({
    
    
      none: 'none',
      0: '0rem',
      xs: '20rem',
      sm: '24rem',
      md: '28rem',
      lg: '32rem',
      xl: '36rem',
      '2xl': '42rem',
      '3xl': '48rem',
      '4xl': '56rem',
      '5xl': '64rem',
      '6xl': '72rem',
      '7xl': '80rem',
      full: '100%',
      min: 'min-content',
      max: 'max-content',
      prose: '65ch',
      ...breakpoints(theme('screens')),
    }),
    minHeight: {
    
    
      0: '0',
      full: '100%',
      screen: '100vh',
    },
    minWidth: {
    
    
      0: '0',
      full: '100%',
      min: 'min-content',
      max: 'max-content',
    },
    objectPosition: {
    
    
      bottom: 'bottom',
      center: 'center',
      left: 'left',
      'left-bottom': 'left bottom',
      'left-top': 'left top',
      right: 'right',
      'right-bottom': 'right bottom',
      'right-top': 'right top',
      top: 'top',
    },
    opacity: {
    
    
      0: '0',
      10: '0.1',
      20: '0.2',
      25: '0.25',
      30: '0.3',
      40: '0.4',
      50: '0.5',
      60: '0.6',
      70: '0.7',
      75: '0.75',
      80: '0.8',
      90: '0.9',
      100: '1',
    },
    order: {
    
    
      first: '-9999',
      last: '9999',
      none: '0',
      1: '1',
      2: '2',
      3: '3',
      4: '4',
      5: '5',
      6: '6',
      7: '7',
      8: '8',
      9: '9',
      10: '10',
      11: '11',
      12: '12',
    },
    outline: {
    
    
      none: ['2rpx solid transparent', '2rpx'],
      white: ['2rpx dotted white', '2rpx'],
      black: ['2rpx dotted black', '2rpx'],
    },
    padding: (theme) => theme('spacing'),
    placeholderColor: (theme) => theme('colors'),
    placeholderOpacity: (theme) => theme('opacity'),
    space: (theme, {
     
      negative }) => ({
    
    
      ...theme('spacing'),
      ...negative(theme('spacing')),
    }),
    stroke: {
    
    
      current: 'currentColor',
    },
    strokeWidth: {
    
    
      0: '0',
      1: '1',
      2: '2',
    },
    textColor: (theme) => theme('colors'),
    textOpacity: (theme) => theme('opacity'),
    width: (theme) => ({
    
    
      auto: 'auto',
      ...theme('spacing'),
      '1_2': '50%',
      '1_3': '33.333333%',
      '2_3': '66.666667%',
      '1_4': '25%',
      '2_4': '50%',
      '3_4': '75%',
      '1_5': '20%',
      '2_5': '40%',
      '3_5': '60%',
      '4_5': '80%',
      '1_6': '16.666667%',
      '2_6': '33.333333%',
      '3_6': '50%',
      '4_6': '66.666667%',
      '5_6': '83.333333%',
      '1_12': '8.333333%',
      '2_12': '16.666667%',
      '3_12': '25%',
      '4_12': '33.333333%',
      '5_12': '41.666667%',
      '6_12': '50%',
      '7_12': '58.333333%',
      '8_12': '66.666667%',
      '9_12': '75%',
      '10_12': '83.333333%',
      '11_12': '91.666667%',
      full: '100%',
      screen: '100vw',
      min: 'min-content',
      max: 'max-content',
    }),
    zIndex: {
    
    
      auto: 'auto',
      0: '0',
      10: '10',
      20: '20',
      30: '30',
      40: '40',
      50: '50',
    },
    gap: (theme) => theme('spacing'),
    gridTemplateColumns: {
    
    
      none: 'none',
      1: 'repeat(1, minmax(0, 1fr))',
      2: 'repeat(2, minmax(0, 1fr))',
      3: 'repeat(3, minmax(0, 1fr))',
      4: 'repeat(4, minmax(0, 1fr))',
      5: 'repeat(5, minmax(0, 1fr))',
      6: 'repeat(6, minmax(0, 1fr))',
      7: 'repeat(7, minmax(0, 1fr))',
      8: 'repeat(8, minmax(0, 1fr))',
      9: 'repeat(9, minmax(0, 1fr))',
      10: 'repeat(10, minmax(0, 1fr))',
      11: 'repeat(11, minmax(0, 1fr))',
      12: 'repeat(12, minmax(0, 1fr))',
    },
    gridAutoColumns: {
    
    
      auto: 'auto',
      min: 'min-content',
      max: 'max-content',
      fr: 'minmax(0, 1fr)',
    },
    gridColumn: {
    
    
      auto: 'auto',
      'span-1': 'span 1 / span 1',
      'span-2': 'span 2 / span 2',
      'span-3': 'span 3 / span 3',
      'span-4': 'span 4 / span 4',
      'span-5': 'span 5 / span 5',
      'span-6': 'span 6 / span 6',
      'span-7': 'span 7 / span 7',
      'span-8': 'span 8 / span 8',
      'span-9': 'span 9 / span 9',
      'span-10': 'span 10 / span 10',
      'span-11': 'span 11 / span 11',
      'span-12': 'span 12 / span 12',
      'span-full': '1 / -1',
    },
    gridColumnStart: {
    
    
      auto: 'auto',
      1: '1',
      2: '2',
      3: '3',
      4: '4',
      5: '5',
      6: '6',
      7: '7',
      8: '8',
      9: '9',
      10: '10',
      11: '11',
      12: '12',
      13: '13',
    },
    gridColumnEnd: {
    
    
      auto: 'auto',
      1: '1',
      2: '2',
      3: '3',
      4: '4',
      5: '5',
      6: '6',
      7: '7',
      8: '8',
      9: '9',
      10: '10',
      11: '11',
      12: '12',
      13: '13',
    },
    gridTemplateRows: {
    
    
      none: 'none',
      1: 'repeat(1, minmax(0, 1fr))',
      2: 'repeat(2, minmax(0, 1fr))',
      3: 'repeat(3, minmax(0, 1fr))',
      4: 'repeat(4, minmax(0, 1fr))',
      5: 'repeat(5, minmax(0, 1fr))',
      6: 'repeat(6, minmax(0, 1fr))',
    },
    gridAutoRows: {
    
    
      auto: 'auto',
      min: 'min-content',
      max: 'max-content',
      fr: 'minmax(0, 1fr)',
    },
    gridRow: {
    
    
      auto: 'auto',
      'span-1': 'span 1 / span 1',
      'span-2': 'span 2 / span 2',
      'span-3': 'span 3 / span 3',
      'span-4': 'span 4 / span 4',
      'span-5': 'span 5 / span 5',
      'span-6': 'span 6 / span 6',
      'span-full': '1 / -1',
    },
    gridRowStart: {
    
    
      auto: 'auto',
      1: '1',
      2: '2',
      3: '3',
      4: '4',
      5: '5',
      6: '6',
      7: '7',
    },
    gridRowEnd: {
    
    
      auto: 'auto',
      1: '1',
      2: '2',
      3: '3',
      4: '4',
      5: '5',
      6: '6',
      7: '7',
    },
    transformOrigin: {
    
    
      center: 'center',
      top: 'top',
      'top-right': 'top right',
      right: 'right',
      'bottom-right': 'bottom right',
      bottom: 'bottom',
      'bottom-left': 'bottom left',
      left: 'left',
      'top-left': 'top left',
    },
    scale: {
    
    
      0: '0',
      50: '.5',
      75: '.75',
      90: '.9',
      95: '.95',
      100: '1',
      105: '1.05',
      110: '1.1',
      125: '1.25',
      150: '1.5',
    },
    rotate: {
    
    
      '-180': '-180deg',
      '-90': '-90deg',
      '-45': '-45deg',
      '-12': '-12deg',
      '-6': '-6deg',
      '-3': '-3deg',
      '-2': '-2deg',
      '-1': '-1deg',
      0: '0',
      1: '1deg',
      2: '2deg',
      3: '3deg',
      6: '6deg',
      12: '12deg',
      45: '45deg',
      90: '90deg',
      180: '180deg',
    },
    translate: (theme, {
     
      negative }) => ({
    
    
      ...theme('spacing'),
      ...negative(theme('spacing')),
      '1_2': '50%',
      '1_3': '33.333333%',
      '2_3': '66.666667%',
      '1_4': '25%',
      '2_4': '50%',
      '3_4': '75%',
      full: '100%',
      '-1_2': '-50%',
      '-1_3': '-33.333333%',
      '-2_3': '-66.666667%',
      '-1_4': '-25%',
      '-2_4': '-50%',
      '-3_4': '-75%',
      '-full': '-100%',
    }),
    skew: {
    
    
      '-12': '-12deg',
      '-6': '-6deg',
      '-3': '-3deg',
      '-2': '-2deg',
      '-1': '-1deg',
      0: '0',
      1: '1deg',
      2: '2deg',
      3: '3deg',
      6: '6deg',
      12: '12deg',
    },
    transitionProperty: {
    
    
      none: 'none',
      all: 'all',
      DEFAULT: 'background-color, border-color, color, fill, stroke, opacity, box-shadow, transform',
      colors: 'background-color, border-color, color, fill, stroke',
      opacity: 'opacity',
      shadow: 'box-shadow',
      transform: 'transform',
    },
    transitionTimingFunction: {
    
    
      linear: 'linear',
      in: 'cubic-bezier(0.4, 0, 1, 1)',
      out: 'cubic-bezier(0, 0, 0.2, 1)',
      'in-out': 'cubic-bezier(0.4, 0, 0.2, 1)',
    },
    transitionDuration: {
    
    
      75: '75ms',
      100: '100ms',
      150: '150ms',
      200: '200ms',
      300: '300ms',
      500: '500ms',
      700: '700ms',
      1000: '1000ms',
    },
    transitionDelay: {
    
    
      75: '75ms',
      100: '100ms',
      150: '150ms',
      200: '200ms',
      300: '300ms',
      500: '500ms',
      700: '700ms',
      1000: '1000ms',
    },
    animation: {
    
    
      none: 'none',
      spin: 'spin 1s linear infinite',
      ping: 'ping 1s cubic-bezier(0, 0, 0.2, 1) infinite',
      pulse: 'pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite',
      bounce: 'bounce 1s infinite',
    },
    keyframes: {
    
    
      spin: {
    
    
        to: {
    
     transform: 'rotate(360deg)' },
      },
      ping: {
    
    
        '75%, 100%': {
    
     transform: 'scale(2)', opacity: '0' },
      },
      pulse: {
    
    
        '50%': {
    
     opacity: '.5' },
      },
      bounce: {
    
    
        '0%, 100%': {
    
    
          transform: 'translateY(-25%)',
          animationTimingFunction: 'cubic-bezier(0.8,0,1,1)',
        },
        '50%': {
    
    
          transform: 'none',
          animationTimingFunction: 'cubic-bezier(0,0,0.2,1)',
        },
      },
    },
  },
  variants: {
    
    
    extend: {
    
    },
  },
  plugins: [],
  corePlugins: {
    
    //禁用一些小程序class不支持的分割
    preflight: false,
    space: false,
    divideWidth: false,
    divideColor: false,
    divideStyle: false,
    divideOpacity: false,
  }
}

额外补充 vscode 插件 及gitee demo例子

uniapp-snippet (uniapp 代码片段提示)
Tailwind CSS IntelliSense (tailwindcss 代码提示)
Tailwind CSS Transpiler (tailwindcss 转换为纯css文件)

gitee例子:uniapp-vue3-ts-tailwindcss-demo
例子 效果

在这里插入图片描述

在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/weixin_43245095/article/details/121222623
今日推荐