为什么Webpack忽略了我的CSS文件?

3
我将尝试使用webpack编译我的CSS文件(使用PostCSS),使其生成一个单独的文件。根据文档,ExtractTextPlugin应该可以实现这一点。但是,我无法让webpack处理我的CSS文件。
相关项目结构:
dist
 ⎣js
   ⎣bundle.js
public
 ⎣css
   ⎣style.css*
src
 ⎣css
   ⎣index.css

* file doesn’t exist (hasn’t been created)

webpack.config.babel.js

import webpack from 'webpack';
import path from 'path';

import ExtractTextPlugin from 'extract-text-webpack-plugin';

import { WDS_PORT } from './src/shared/config';
import { isProd } from './src/shared/util';

export default {
  entry: [
    'react-hot-loader/patch',
    './src/client',
  ],
  output: {
    filename: 'js/bundle.js',
    path: path.resolve(__dirname, 'dist'),
    publicPath: isProd ? '/static/' : `http://localhost:${ WDS_PORT }/dist/`,
  },
  module: {
    rules: [
      { test: /\.(js|jsx)$/, use: 'babel-loader', exclude: /node_modules/ },
      {
        test: /\.css$/,
        use: ExtractTextPlugin.extract({
          fallback: 'style-loader',
          use: [
            {
              loader: 'style-loader',
            },
            {
              loader: 'css-loader',
              options: {
                sourceMap: true,
                importLoaders: 1,
              },
            },
            {
              loader: 'postcss-loader',
              options: {
                sourceMap: 'inline',
              },
            },
          ],
        }),
      },
    ],
  },
  devtool: isProd ? false : 'source-map',
  resolve: {
    extensions: ['.js', '.jsx', '.css'],
  },
  devServer: {
    port: WDS_PORT,
    hot: true,
  },
  plugins: [
    new webpack.optimize.OccurrenceOrderPlugin(),
    new webpack.HotModuleReplacementPlugin(),
    new webpack.NamedModulesPlugin(),
    new webpack.NoEmitOnErrorsPlugin(),
    new ExtractTextPlugin('./public/css/style.css'),
  ],
};

这将可以正确编译我的JavaScript,但对我的CSS没有任何影响。出了什么问题?我该如何解决?

值得注意的是:如果我从方程中删除postCSS,只使用use: 'css-loader',它仍然无效。 - futuraprime
你有在命令行中运行Webpack时检查输出吗? - Sebastianb
1个回答

6

Webpack只会处理被导入的文件,这些文件要么是指定的入口点,要么是在任何从入口点引用的文件中被导入。规则不会导入任何文件,它们只会在导入通过测试(符合你现在的正则表达式)时被应用。

你需要像任何其他模块一样导入你的CSS。

import './css/index.css';

另请参阅代码分割 - CSS


我在参加培训课程时遇到了同样的问题,谢谢! - undefined

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接