繁体   English   中英

为什么我的样式表没有包含在 Webpack 构建中?

[英]Why aren't my stylesheets being included in the Webpack build?

Webpack 将文件(.css、.js)收集到一个库中,并在另一个 React 项目中使用它。 组件中指定的样式不会通过,尽管 .css 文件存在并且样式在那里。

UiButton.jsx 文件

import styles from './UiButton.module.css';

const UiButton = () => {
    return (
        <>
            <button className={styles.button}>Text</button>
        </>
    );
}

export default UiButton;

index.js 文件

import UiButton from './UiButton/UiButton';
import './index.css';

export { UiButton };

Webpack.config.js 文件

const path = require('path');
const webpack = require('webpack');
const MiniCssExtractPlugin = require("mini-css-extract-plugin");
// const HtmlWebpackPlugin = require('html-webpack-plugin');
const { CleanWebpackPlugin } = require('clean-webpack-plugin');

module.exports = {
  entry: { main: './src/index.js' },
  output: {
    path: path.resolve(__dirname, 'dist'),
    filename: 'index.js',
    libraryTarget: "umd",
    library: "uilibrarytest"
  },
  module: {
    rules: [
      {
        test: /\.(js|jsx)$/,
        exclude: /node_modules/,
        use: {
          loader: "babel-loader"
        }
      },
      {
        test: /\.css$/,
        use:  [  'style-loader', MiniCssExtractPlugin.loader, 'css-loader' ]
      }
    ]
  },
  plugins: [ 
    new CleanWebpackPlugin(),
    new MiniCssExtractPlugin({
        filename: 'index.css',
    }),
    // new HtmlWebpackPlugin({
    //     template: './public/index.html',
    // }),
    new webpack.ProvidePlugin({
        "React": "react",
      }),
  ],
  resolve: {
    extensions: ['.js', '.jsx'],
  },
}

这是 webpack 构建的:

.button {
    background: red;
}
html {
  margin: 0;
  padding: 0;
}

如何使它在使用给定库中的组件时,样式也被拉到它?

Webpack 中的加载器是从右到左评估的。 在您的配置中,评估顺序是“css-loader”、MiniCssExtractPlugin.loader,最后是“style-loader”。 但是 'style-loader' 只将样式注入到 DOM 中。 您需要 MiniCssExtractPlugin.loader 成为“use”数组中的第一个元素。 见下文...

{ 
  test: /\.css$/, 
  use: [ MiniCssExtractPlugin.loader, 'css-loader' ] 
}

此外,您可以告诉 webpack 在生产期间使用 MiniCssExtractPlugin.loader ,而在其他时候使用 'style-loader'。

const isProduction = process.env.NODE_ENV == 'production';
const stylesHandler = isProduction ? MiniCssExtractPlugin.loader : 'style-loader';

...other config

{ 
  test: /\.css$/, 
  use: [ stylesHandler, 'css-loader' ] 
}

在你的 package.json 脚本中,

"build": "webpack --mode=production --node-env=production"

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM