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

module.exports = {
    entry: {
        libs: ['./app.js', 'vue', 'vue-router', 'iview']
    },
    output: {
        path: path.join(__dirname, '../bundle'),
        filename: '[name].[hash:7].js',
        chunkFilename: '[name].[hash:7].chunk.js'
    },
    resolve: {
        extensions: ['.js', '.vue', '.json'],
        alias: {
            vue$: 'vue/dist/vue.esm.js',
            'echarts-lib': 'echarts/lib/echarts',
            'echarts-tooltip': 'echarts/lib/component/tooltip',
            'echarts-legend': 'echarts/lib/component/legend',
            'echarts-line': 'echarts/lib/chart/line',
            'echarts-pie': 'echarts/lib/chart/pie'
        },
        modules: [
            util.resolve('components'),
            util.resolve('scss'),
            util.resolve('config'),
            util.resolve('services'),
            'node_modules'
        ]
    },
    devServer: {
        host: '0.0.0.0',
        port: 6006,
        hot: false,
        inline: true,
        compress: true,
        stats: {
            colors: true,
            children: false,
            chunks: false,
            assetsSort: 'size',
        },
        headers: {
            'Access-Control-Allow-Origin': '*'
        },
        proxy: {
            '**': 'http://localhost:6007'
        }
    },
    module: {
        rules: [
            {
                test: /\.js$/,
                loader: 'babel-loader',
                include: [util.resolve('/')]
            },
            {
                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].[hash:7].[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('[name].[hash:7].css'),
        new webpack.IgnorePlugin(/^\.\/locale$/, /moment$/),
        new HtmlWebpackPlugin({
            filename: 'index.html',
            template: 'index.html',
            inject: true
        })
    ]
};