Webpack-simple: переменные SASS не переводятся в свои значения на странице - PullRequest
0 голосов
/ 07 ноября 2018

После установки Vue-CLI с webpack-simple, а затем npm install sass-loader node-sass webpack --save-dev у меня есть style.scss в моем /src folder.

Однако, несмотря на следование документам Vue.js , SCSS не работает должным образом: если я создаю SCSS переменную $gray1: #dddddd, тогда использую ее как background: $gray, $gray не переводится в #dddddd в браузере (консоль показывает background: $gray1, что, конечно, не имеет смысла в Chrome).

Есть ли какой-то особый шаг, чтобы заставить SASS работать в этом случае?

Содержимое моего Webpack.config.js файла:

var path = require('path')
var webpack = require('webpack')

module.exports = {
  entry: './src/main.js',
  output: {
    path: path.resolve(__dirname, './dist'),
    publicPath: '/dist/',
    filename: 'build.js'
  },
  module: {
    rules: [
      {
        test: /\.css$/,
        use: [
          'vue-style-loader',
          'css-loader',
          {
          loader: 'sass-loader',
          options: {}
          }
        ],
      },
      {
        test: /\.vue$/,
        loader: 'vue-loader',
        options: {
          loaders: {
          }
          // other vue-loader options go here
        }
      },
      {
        test: /\.js$/,
        loader: 'babel-loader',
        exclude: /node_modules/
      },
      {
        test: /\.(png|jpg|gif|svg)$/,
        loader: 'file-loader',
        options: {
          name: '[name].[ext]?[hash]'
        }
      }
    ]
  },
  resolve: {
    alias: {
      'vue$': 'vue/dist/vue.esm.js'
    },
    extensions: ['*', '.js', '.vue', '.json']
  },
  devServer: {
    historyApiFallback: true,
    noInfo: true,
    overlay: true,
    clientLogLevel: 'none'
  },
  performance: {
    hints: false
  },
  devtool: '#eval-source-map'
}

if (process.env.NODE_ENV === 'production') {
  module.exports.devtool = '#source-map'
  // http://vue-loader.vuejs.org/en/workflow/production.html
  module.exports.plugins = (module.exports.plugins || []).concat([
    new webpack.DefinePlugin({
      'process.env': {
        NODE_ENV: '"production"'
      }
    }),
    new webpack.optimize.UglifyJsPlugin({
      sourceMap: true,
      compress: {
        warnings: false
      }
    }),
    new webpack.LoaderOptionsPlugin({
      minimize: true
    })
  ])
}

Вот как я импортирую мой style.scss файл в мой основной компонент:

<style>
@import '../style.scss';
</style>

Ответы [ 7 ]

0 голосов
/ 28 ноября 2018

С вашими правилами, это должно работать ... Если ваш style.scss находится в папке src, попробуйте изменить путь импорта вместо:

<style lang="scss">
  @import './style.scss';
</style>
0 голосов
/ 14 декабря 2018

В случае, если кто-то с той же проблемой сталкивался с этим потоком, проблема заключалась в том, что я забыл указать lang="scss" при вызове моего SCSS файла:

<style lang="scss">
  @import './style.scss';
</style>

Все CSS, содержащиеся в style.scss, все еще работают. Что касается SCSS переменных, определенных или используемых в нем, они не работали. Теперь они делают.

Почему-то никто этого не заметил:)

0 голосов
/ 25 ноября 2018

Глядя на мои собственные конфиги и файлы, меняем правило:

  {
    test: /\.css$/,
    use: [
      'vue-style-loader',
      'css-loader',
      {
      loader: 'sass-loader',
      options: {}
      }
    ],
  },

до

        {
            test: /\.s[a|c]ss$/,
            loader: "style!css!sass"
        },

для вашего <style> в вашем SFC, вам также нужен lang, т.е. <style lang="scss">

и, если вы импортируете, вам может понадобиться поставить ~ перед вашим путем, например, @import "~../style.scss";

0 голосов
/ 16 ноября 2018

Попробуйте изменить правила для sass примерно так

{ 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 }] }

0 голосов
/ 16 ноября 2018

Я не могу найти источник прямо сейчас. Но если экспортируемый вами файл SASS содержит переменные, которые вы пытаетесь использовать в других файлах / тегах стиля SASS, имя файла должно начинаться с подчеркивания .

style.scss -> _style.scss

Если только файл SASS использует переменные SASS из других файлов SASS, то для него не требуется начальное подчеркивание.

0 голосов
/ 13 ноября 2018

Попробуйте что-то вроде этого:

{
  test: /\.(css|scss)$/,
  use: [isProduction ? MiniCssExtractPlugin.loader : "style-loader", "css-loader", "sass-loader"],
}
0 голосов
/ 07 ноября 2018

Убедитесь, что вы выполнили следующие действия:

В вашем импорте конфигурации веб-пакета extract-text-webpack-plugin.

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

После ввода вашей записи scss в конфиг:

module.exports = {
  entry: ['app.js', 'anotherfile.scss', './scss/your-main-file.scss'],
...

А в модуле ..

...
module: {

    rules: [

      {
        test: /\.(sass|scss)$/,
        loader: ExtractTextPlugin.extract(['css-loader', 'sass-loader'])
      }
    ]
  },
...

Выполнение этих шагов и правильная установка модулей должны работать на вас. Удачи с этим!

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...