[英]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.