-
Notifications
You must be signed in to change notification settings - Fork 25
/
Copy pathwebpack.config.js
40 lines (38 loc) · 1.52 KB
/
webpack.config.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
var path = require('path');
// to see the solutions in the browser, switch out the file path at the 'entry' property.
// For exercise 2 solution, use './solutions/exercise-2/index.js'
// For exercise 3 solution, use './solutions/exercise-3/index.js'
// For exercise 4 solution, use './solutions/exercise-4/index.js'
// For exercise 5 solution, use './solutions/exercise-5/index.js'
// For exercise 5 bonus solution, use './solutions/exercise-5-bonus/index.js'
// For main project, use './src/index.js'
module.exports = {
// entry: webpack's entry file, where webpack will start looking to build it's dependency graph
entry: './src/index.js',
// output: where webpack will put the 'bundle' of code it made from packaging dependencies
output: {
// the filename of the output file
filename: 'bundle.js',
// the path to the directory where the output file should go
path: path.resolve(__dirname, 'dist')
},
// these are configurations for the dev server
devtool: 'inline-source-map',
devServer: {
contentBase: path.join(__dirname, 'dist'),
historyApiFallback: true,
port: 9000
},
resolve: {
extensions: ['.js', '.jsx', '.json']
},
// webpack only understands javascript! loaders transform files into modules for webpack
module: {
// this is an array of loaders
loaders: [
// test determines which file extensions to run the loader on
{ test: /\.jsx?$/, loader: 'babel-loader', exclude: /node_modules/ },
{ test: /\.css$/, use: ['style-loader', 'css-loader']}
]
}
};