在 next.js 中使用 css 模块的顺风 css

Mas*_*iri 13 sass reactjs css-modules next.js tailwind-css

如何配置 next.js 以支持带有 css 模块的同步顺风 css?我想要 tailwindcss 包装整个项目:

// /tailwind.scss
:global {
  @import "tailwindcss/base";
  @import "tailwindcss/components";
  @import "tailwindcss/utilities";
}

// /test-module.css
.example {
  font-size: 36px;
}

Run Code Online (Sandbox Code Playgroud)
// /pages/_app.jsx
import '../talwind.scss';
...
Run Code Online (Sandbox Code Playgroud)

在示例组件中:

// /components/my-component.jsx
import css from '../test-module.css';

const Test = () => (
  <div className={`bg-red-500` ${css.example}}>Test Tailwind with CSS</div>
);


Run Code Online (Sandbox Code Playgroud)

Mas*_*iri 5

一个解决方案是拆分 webpack 样式加载器。一个用于全局 css 的加载器,另一个用于 css 模块的加载器,因此 webpack 加载器如下所示:

{
  test: /\.s?[ac]ss$/,
  exclude: /\.global.css$/,
  use: [
    {
      loader: MiniCssExtractPlugin.loader,
      options: {
        hmr: !isProduction,
        reloadAll: true,
      },
    },
    // 'css-loader',
    {
      loader: 'css-loader',
      options: {
        importLoaders: 1,
        modules: {
          localIdentName: '[name]__[local]___[hash:base64:5]',
        },
      },
    },
    'postcss-loader',
    { loader: 'sass-loader', options: { sourceMap: true } },
  ],
},
{
  test: /\.global.css$/,
  use: [
    {
      loader: MiniCssExtractPlugin.loader,
      options: {
        hmr: !isProduction,
        reloadAll: true,
      },
    },
    'css-loader',
    'postcss-loader',
  ],
},
Run Code Online (Sandbox Code Playgroud)