webpack.base.conf.js 3.71 KB
const webpack = require('webpack');
const ExtractTextPlugin = require('extract-text-webpack-plugin');
const HtmlWebpackPlugin = require('html-webpack-plugin');
const CleanWebpackPlugin = require('clean-webpack-plugin');
const util = require('./util');

module.exports = {
    entry: {
        libs: ['vue', 'vue-router'],
        view: ['iview'],
        app: ['./app.js']
    },
    output: {
        path: util.resolve('./build/bundle'),
        filename: '[name].[hash:7].js',
        chunkFilename: '[name].[hash:7].js',
        publicPath: '/'
    },
    resolve: {
        extensions: ['.js', '.vue', '.json'],
        alias: {
            vue$: 'vue/dist/vue.esm.js'
        },
        modules: [
            util.resolve('components'),
            util.resolve('scss'),
            util.resolve('config'),
            util.resolve('services'),
            'node_modules'
        ]
    },
    devServer: {
        host: '0.0.0.0',
        port: 6008,
        hot: false,
        inline: true,
        compress: true,
        stats: {
            colors: true,
            children: false,
            chunks: false,
            assetsSort: 'size',
        },
        historyApiFallback: {
            rewrites: [
                { from: /\.html$/, to: '/index.html' },
                { from: /.*?\.(js)|(css)$/,
                    to: (context) => {
                        return context.parsedUrl.pathname;
                    }
                }
            ]
        },
        headers: {
            'Access-Control-Allow-Origin': '*'
        },
        proxy: {
            '/Api': 'http://localhost:6007'
        }
    },
    module: {
        rules: [
            {
                test: /\.js$/,
                loader: 'babel-loader',
                include: [util.resolve('/')],
                exclude: /node_modules/
            },
            {
                test: /\.(png|jpe?g|gif|svg)(\?.*)?$/,
                loader: 'url-loader',
                options: {
                    limit: 10000,
                    name: 'img/[name].[hash:7].[ext]'
                }
            },
            {
                test: /\.(woff2?|eot|ttf|otf)(\?.*)?$/,
                loader: 'url-loader',
                options: {
                    limit: 10000,
                    name: 'fonts/[name].[ext]'
                }
            },
            {
                test: /\.vue$/,
                loader: 'vue-loader',
                // include: [util.resolve('pages'), util.resolve('components')],
                options: {
                    loaders: {
                        scss: ExtractTextPlugin.extract({
                            use: 'css-loader!sass-loader',
                            fallback: 'vue-style-loader'
                        })
                    }
                }
            }, {
                test: /\.css$/,
                loader: ExtractTextPlugin.extract({
                    use: 'css-loader',
                    fallback: 'style-loader'
                })
            }, {
                test: /\.scss$/,
                loader: ExtractTextPlugin.extract({
                    use: 'css-loader!sass-loader',
                    fallback: 'style-loader'
                })
            }
        ]
    },
    plugins: [
        new ExtractTextPlugin('style.[hash:7].css'),
        new webpack.IgnorePlugin(/^\.\/locale$/, /moment$/),
        new HtmlWebpackPlugin({
            filename: 'index.html',
            template: 'index.html',
            inject: true
        }),
        new webpack.optimize.CommonsChunkPlugin({
            name: ['view', 'libs'],
        }),
        new CleanWebpackPlugin(['*'], {
            root: util.resolve('./build/bundle'),
            verbose: true,
            dry: false
        })
    ]
};