css - Webpack 将 CSS 编译成奇怪的类名

标签 css node.js reactjs webpack

我目前正在使用webpack使用 NodeJS 后端开发 React 应用程序时。

我在设计应用程序样式时遇到了麻烦,因为 webpack 似乎试图对我的 css 执行某些操作,最终会更改类名。

例如在我的 base.css 中文件我有这个:

body {
  background: #ECEFF1;
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: 15px;
  line-height: 1.7;
  margin: 0 auto;
  padding: 30px;  
  max-width: 980px;
}

.progress {
  background-color: #FFECB3;
}
.progress .indeterminate {
    background-color: #FFC107;
}

当我加载页面并查看头部时,它会转换为 <style> div 具有这些类名:

<style type="text/css">
body {
  background: #ECEFF1;
  font-family: "Helvetica Neue", Helvetica, Arial, sans-serif;
  font-size: 15px;
  line-height: 1.7;
  margin: 0 auto;
  padding: 30px;  
  max-width: 980px;
}

.base---progress---1RR8Z {
  background-color: #FFECB3;
}
.base---progress---1RR8Z .base---indeterminate---23sZH {
    background-color: #FFC107;
}

因此,进度样式不会在页面上被选取,因为它们已更改为这种格式。我怎样才能避免这种情况或让 React 适本地更改类名?

<小时/>

如果我从我的 webpack 配置中删除它:

{
      test: /\.css$/,
      loader: 'style!css?modules&localIdentName=[name]---[local]---[hash:base64:5]'
    }

它说找不到 css 文件,但错误的路径是有效的。

<小时/>

Webpack 配置的良好措施:

'use strict';

var path = require('path');
var webpack = require('webpack');
var HtmlWebpackPlugin = require('html-webpack-plugin');

module.exports = {
  devtool: 'eval-source-map',
  entry: [
    'webpack-hot-middleware/client?reload=true',
    path.join(__dirname, 'public/app/main.js')
  ],
  output: {
    path: path.join(__dirname, '/dist/'),
    filename: '[name].js',
    publicPath: '/'
  },
  plugins: [
    new HtmlWebpackPlugin({
      template: 'public/app/index.html',
      inject: 'body',
      filename: 'index.html'
    }),
    new webpack.optimize.OccurenceOrderPlugin(),
    new webpack.HotModuleReplacementPlugin(),
    new webpack.NoErrorsPlugin(),
    new webpack.DefinePlugin({
      'process.env.NODE_ENV': JSON.stringify('development')
    })
  ],
  module: {
    loaders: [{
      test: /\.jsx?$/,
      exclude: /node_modules/,
      loader: 'babel',
      query: {
        "presets": ["react", "es2015", "stage-0", "react-hmre"]
      }
    }, {
      test: /\.json?$/,
      loader: 'json'
    }, {
      test: /\.css$/,
      loader: 'style!css?modules&localIdentName=[name]---[local]---[hash:base64:5]'
    }]
  }
};

最佳答案

您的配置当前使用css-modules 。禁用它 将 'style!css?modules&localIdentName=[name]---[local]---[hash:base64:5]' 更改为 'style!css' css 文件的加载器。

关于css - Webpack 将 CSS 编译成奇怪的类名,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/38485324/

相关文章:

html - bootstrap 4 (alpha 6) 中的全宽轮播

CSS 溢出字符未向下推 <div>

javascript - Discord.js - 引用错误 : join is not defined

javascript - 将获取的数据推送到对象数组

css - 更改导航栏图像的 CSS 以适应 IE

node.js - 在 ejs 的 locals 对象中找到的选项

Node.js WriteStream 在关闭之前不会将数据写入文件

javascript - 通过 ref 或 prop 更改 React 中的子组件?

reactjs - 使用外部插件 react 应用程序

css - Google +1 按钮作为链接?