webpack sass-loader不生成css

时间:2017-06-16 04:59:07

标签: css reactjs webpack sass-loader

我无法弄清楚如何使用webpack sass-loader渲染css。

App.js文件:

import React, { Component } from 'react';
import logo from './logo.svg';
import './App.css';
import Test from "./Test";

class App extends Component {
  render() {
    return (
      <div className="App">
        <div className="App-header">
          <img src={logo} className="App-logo" alt="logo" />
          <h2>Welcome to React</h2>
        </div>
        <p className="App-intro">
          To get started, edit <code>src/App.js</code> and save to reload.
        </p>
          <Test />
      </div>
    );
  }
}

export default App;

Test.jsx文件:

import React, { Component } from 'react';
import './Test.scss';

class Test extends Component {
    render() {
        return (
            <p className="intro">
                Test
            </p>
        );
    }
}

export default Test;

Test.scss文件:

.intro{
  background-color: #dddddd;
  color: red;
}

webpack.config.dev.js文件:

{
            test: /\.css$/,
            use: [
                require.resolve('style-loader'),
                {
                    loader: require.resolve('css-loader'),
                    options: {
                        importLoaders: 1,
                    },
                },
                {
                    loader: require.resolve('postcss-loader'),
                    options: {
                        ident: 'postcss', // https://webpack.js.org/guides/migrating/#complex-options
                        plugins: () => [
                            require('postcss-flexbugs-fixes'),
                            autoprefixer({
                                browsers: [
                                    '>1%',
                                    'last 4 versions',
                                    'Firefox ESR',
                                    'not ie < 9', // React doesn't support IE8 anyway
                                ],
                                flexbox: 'no-2009',
                            }),
                        ],
                    },
                },
            ],
        },
        {
            test: /\.scss$/,
            use: [{
                loader: "style-loader" // creates style nodes from JS strings
            }, {
                loader: "css-loader" // translates CSS into CommonJS
            }, {
                loader: "sass-loader" // compiles Sass to CSS
            }]
        }

图像:
结果
enter image description here
预期
enter image description here

我对sass loader做错了。它是什么?请帮忙。

       {
            exclude: [
                /\.html$/,
                /\.(js|jsx)$/,
                /\.css$/,
                /\.scss$/,
                /\.json$/,
                /\.bmp$/,
                /\.gif$/,
                /\.jpe?g$/,
                /\.png$/,
            ],
            loader: require.resolve('file-loader'),
            options: {
                name: 'static/media/[name].[hash:8].[ext]',
            },
        }

我在这里添加了/.scss$/,代码运行成功,谢谢大家

1 个答案:

答案 0 :(得分:0)

这就是我在extract-text-webpack-plugin的帮助下使用sass-loader创建单独文件而不是仅将其包含到bundle.js文件的方式。

我正在使用webpack v2.6.1

// webpack-config.js

const ExtractTextPlugin = require('extract-text-webpack-plugin');

    module: {
            rules: [
              { test: /\.css$/, use: ExtractTextPlugin.extract({ fallback: 'style-loader', use: ['css-loader']}) },
              { test: /\.scss$/, use: ExtractTextPlugin.extract({ fallback: 'style-loader', use: ['css-loader', 'sass-loader']}) },
            ],
          },
plugins: [
   new ExtractTextPlugin('[name]-[chunkhash].css'),
]

并将其导入我的index.js,如下所示:

import '../public/assets/sass/style.scss';