@use rules must be written before any other rules 报错

这篇博客介绍了在Vue项目中使用Element-Plus按需加载样式时遇到的CSS预处理器错误`@use rules must be written before any other rules`。作者提供了一个解决方案,即通过修改`preprocessorOptions`的`scss`配置,将`additionalData`改为`@use`语法,从而避免了冲突。这有助于优化项目构建并确保样式正确导入。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

export default defineConfig({
  plugins: [
    vue(),
    styleImport({
      libs: [
        {
          libraryName: 'element-plus',
          esModule: true,
          ensureStyleFile: true,
          resolveStyle: name => {
            name = name.slice(3)
            return `element-plus/packages/theme-chalk/src/${name}.scss`
          },
          resolveComponent: name => {
            return `element-plus/lib/${name}`
          },
        },
      ],
    }),
  ],
  css: {
    preprocessorOptions: {
      scss: {
        additionalData: `@import "@/theme/var.scss";`,
      },
    },
  },
  resolve: {
    alias: {
      '@': resolve('src'),
    },
  },
})

使用了element-plus按需加载样式然后使用css.preprocessorOptions一起使用报错@use rules must be written before any other rules

解决方案如下:

modules.exports = {
    ...    
    css: {
        preprocessorOptions: {
          scss: {
            additionalData: `@use "@/theme/var.scss" as *;`,
          },
        },
    },
    ...
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值