Skip to content

Webpack 插件

UnoCSS 的 webpack 插件:@unocss/webpack。当前,此插件仅支持 global 模式

INFO

该插件不带有任何默认预设。

安装

bash
pnpm add -D @unocss/webpack
bash
yarn add -D @unocss/webpack
bash
npm install -D @unocss/webpack

从 UnoCSS 版本 v0.59.0 开始,UnoCSS 已移至仅支持 ESM,您需要通过动态导入加载您的配置:

ts
// webpack.config.js
module.exports = function () {
  return import('@unocss/webpack').then(({ default: UnoCSS }) => ({
    plugins: [UnoCSS()],
    optimization: {
      realContentHash: true
    }
  }))
}
js
// webpack.config.js
module.exports = function () {
  return import('@unocss/webpack').then(({ default: UnoCSS }) => ({
    plugins: [UnoCSS()],
    css: {
      extract: {
        filename: '[name].[hash:9].css'
      }
    }
  }))
}

如果您使用的是旧版本的 UnoCSS,则可以使用以下代码:

ts
// webpack.config.js
const UnoCSS = require('@unocss/webpack').default

module.exports = {
  plugins: [UnoCSS()],
  optimization: {
    realContentHash: true
  }
}
js
// webpack.config.js
const UnoCSS = require('@unocss/webpack').default

module.exports = {
  plugins: [UnoCSS()],
  css: {
    extract: {
      filename: '[name].[hash:9].css'
    }
  }
}

创建一个 uno.config.ts 文件:

ts
import { defineConfig } from 'unocss'

export default defineConfig({
  // ...UnoCSS options
})

WARNING

如果您使用 webpack@4.x,optimization.realContentHash 配置不受支持,并且应该使用 css.extract.filename 自定义 CSS 文件名(我们使用哈希码的前 9 个字母作为示例)。注意此已知问题与捆绑包以及 webpack#9520

使用

在主入口中添加 uno.css

ts
import 'uno.css'

框架

Vue + Vue CLI

如果您使用 webpack 4/5 和 UnoCSS v0.59.0,您需要使用最新的 Vue CLI Service v5.0.8 来通过动态导入加载您的配置:

ts
// vue.config.js
const process = require('node:process')

module.exports = function () {
  return import('@unocss/webpack').then(({ default: UnoCSS }) => ({
    configureWebpack: {
      devtool: 'inline-source-map',
      plugins: [UnoCSS()],
      optimization: {
        realContentHash: true
      }
    },
    chainWebpack(config) {
      config.module.rule('vue').uses.delete('cache-loader')
      config.module.rule('tsx').uses.delete('cache-loader')
      config.merge({
        cache: false
      })
    },
    css: {
      extract:
        process.env.NODE_ENV === 'development'
          ? {
              filename: 'css/[name].css',
              chunkFilename: 'css/[name].css'
            }
          : true
    }
  }))
}
ts
// vue.config.js
const process = require('node:process')

module.exports = function () {
  return import('@unocss/webpack').then(({ default: UnoCSS }) => ({
    configureWebpack: {
      plugins: [UnoCSS({})]
    },
    chainWebpack(config) {
      config.module.rule('vue').uses.delete('cache-loader')
      config.module.rule('tsx').uses.delete('cache-loader')
      config.merge({
        cache: false
      })
    },
    css: {
      extract:
        process.env.NODE_ENV === 'development'
          ? {
              filename: '[name].css',
              chunkFilename: '[name].[hash:9].css'
            }
          : true
    }
  }))
}

如果使用旧版本的 UnoCSS,则可以使用以下代码:

ts
// vue.config.js
const process = require('node:process')
const UnoCSS = require('@unocss/webpack').default

module.exports = {
  configureWebpack: {
    devtool: 'inline-source-map',
    plugins: [UnoCSS()],
    optimization: {
      realContentHash: true
    }
  },
  chainWebpack(config) {
    config.module.rule('vue').uses.delete('cache-loader')
    config.module.rule('tsx').uses.delete('cache-loader')
    config.merge({
      cache: false
    })
  },
  css: {
    extract:
      process.env.NODE_ENV === 'development'
        ? {
            filename: 'css/[name].css',
            chunkFilename: 'css/[name].css'
          }
        : true
  }
}
ts
// vue.config.js
const process = require('node:process')
const UnoCSS = require('@unocss/webpack').default

module.exports = {
  configureWebpack: {
    plugins: [UnoCSS({})]
  },
  chainWebpack(config) {
    config.module.rule('vue').uses.delete('cache-loader')
    config.module.rule('tsx').uses.delete('cache-loader')
    config.merge({
      cache: false
    })
  },
  css: {
    extract:
      process.env.NODE_ENV === 'development'
        ? {
            filename: '[name].css',
            chunkFilename: '[name].[hash:9].css'
          }
        : true
  }
}

Released under the MIT License.