zoukankan      html  css  js  c++  java
  • tailwindcss 支持微信小程序配置

    安装postcss插件

    npm install -D postcss-class-rename css-byebye

    • postcss-class-rename 是将小程序不支持的css类重命名
    • css-byebye 移除不支持的css类,比如:* {}

    tailwindcss配置移除不支持的css样式

    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: {
        extend: {},
        // Disable breakpoints
        screen: {}
      },
      variants: {
        extend: {},
      },
      plugins: [],
      corePlugins: {
        preflight: false,
        space: false,
        divideWidth: false,
        divideColor: false,
        divideStyle: false,
        divideOpacity: false,
      }
    }
    
    

    由于上面space/divideWidth等样式包含微信小程序不支持的写法:.className > :not([hidden]) ~ :not([hidden]),所以移除。

    uniapp 配置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
          }
        }),
    
        /* ******* 引入tailwindcss ******* */
        require('tailwindcss')({}),
    
        // // 根据平台差异进行不同的样式处理
        ...(
          process.env.UNI_PLATFORM !== "h5"
            ? [
              // 使用postcss-class-name 包将小程序不支持的类名转换为支持的类名
              require("postcss-class-rename")({
                "\\:": "--",
                // "\\/": "--",
                "\\.": "--",
                ".:": "--"
              }),
              require("css-byebye")({
                rulesToRemove: [
                  /*/
                ],
                map: false
              })
            ]
            : [
              require("autoprefixer")({
                remove: true,
              }),
            ]
        ),
        /* ******* */
    
        require('@dcloudio/vue-cli-plugin-uni/packages/postcss')
      ]
    }
    
    

    /* ******* ******* */之间是关键配置

  • 相关阅读:
    六、Oracle的数据库管理及数据字典和动态视图
    八、Oracle的数据完整性
    js回调函数
    PL/SQL编程(三)
    四、Oracle的复杂查询
    三、Oracle的简单查询
    C#实现双向链表
    什么是Unix时间戳 [转]
    ANSI escape sequences
    Gibbs Sampling [转]
  • 原文地址:https://www.cnblogs.com/li1234yun/p/14257579.html
Copyright © 2011-2022 走看看