123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081 |
- const path = require('path');
- const htmlWebpackPlugin = require('html-webpack-plugin');
- module.exports = {
- mode: 'development',
- entry: './src/app.js',
- output: {
- filename: 'bundle.js',
- path: path.resolve(__dirname, '../dist'),
- },
- node: {
- fs: 'empty',
- child_process: 'empty',
- },
- module: {
- rules: [
- {
- test: /\.js$/,
- use: 'babel-loader',
- exclude: '/node_modules/',
- },
- {
- test: /\.css$/,
- use: ['style-loader', 'css-loader'],
- },
- {
- test: /\.s[ac]ss$/i,
- use: [
- // Creates `style` nodes from JS strings
- 'style-loader',
- // Translates CSS into CommonJS
- 'css-loader',
- // Compiles Sass to CSS
- 'sass-loader',
- ],
- },
- {
- test: /\.less$/,
- exclude: /\.module\.less$/,
- loader: [
- 'style-loader',
- 'css-loader',
- // 'css-loader?modules',
- 'less-loader'
- ]
- },
- {
- test: /\.module\.less$/,
- loader: [
- 'style-loader',
- // 'css-loader',
- {
- loader: 'css-loader',
- options: {
- modules: {
- localIdentName: '[local]_[hash:base64:5]',
- }
- }
- },
- // 'css-loader?modules',
- 'less-loader'
- ]
- },
- {
- test: /\.(mp3|mp4)$/,
- loader: 'url-loader',
- options: {
- name: '[name].[ext]',
- },
- },
- ],
- },
- devServer: {
- contentBase: './dist',
- },
- plugins: [
- new htmlWebpackPlugin({
- template: 'public/index.html',
- }),
- ],
- };
|