Skip to content

Instantly share code, notes, and snippets.

@hwindo
Created August 5, 2018 22:31
Show Gist options
  • Save hwindo/c92033d6c11d0e4335253a0c4a0ac481 to your computer and use it in GitHub Desktop.
Save hwindo/c92033d6c11d0e4335253a0c4a0ac481 to your computer and use it in GitHub Desktop.
basic-webpack-scss

basic-webpack-scss

gist version

Minimum Webpack configuration SCSS with hot module reloading for development

Features:

usage

  • create folder /src and add file /src/app.js for main entry
  • create file src/style.scss
  • create folder /dist and add file /dist/index.html include
  • <script src="app.jc"></script> before body close tag
  • npm start to run development using webpack dev server
{
"name": "basic-webpack-scss",
"version": "1.0.0",
"description": "Minimum Webpack SCSS for development",
"main": "",
"scripts": {
"build": "webpack --watch",
"start": "webpack-dev-server --open"
},
"author": "Herwindo Artono",
"license": "MIT",
"devDependencies": {
"css-loader": "^1.0.0",
"node-sass": "^4.9.2",
"sass-loader": "^7.1.0",
"style-loader": "^0.21.0",
"webpack": "^4.16.4",
"webpack-cli": "^3.1.0",
"webpack-dev-server": "^3.1.5"
}
}
const path = require('path');
const webpack = require('webpack');
module.exports = {
entry: {
app: './src/app.js'
},
mode: 'development',
output: {
filename: '[name].js',
path: path.resolve(__dirname, 'dist')
},
devtool: 'inline-source-map',
devServer: {
contentBase: './dist',
hot: true
},
plugins: [
new webpack.HotModuleReplacementPlugin(),
],
module: {
rules: [
{
test: /\.css$/,
use: [
'style-loader',
'css-loader'
]
},
{
test: /\.scss$/,
use: [
'style-loader',
'css-loader',
'sass-loader'
]
}
]
}
}
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment