webpack.dev.config.js 3.85 KB
/**
 * 本地预览
 */

var path = require('path');
var webpack = require('webpack');
// var ExtractTextPlugin = require('extract-text-webpack-plugin');
var HtmlWebpackPlugin = require('html-webpack-plugin');

module.exports = {
    // 入口
    entry: {
        main: './test/main',
        vendors: ['vue', 'vue-router']
    },
    // 输出
    output: {
        path: path.join(__dirname, '../test/dist'),
        publicPath: '',
        filename: '[name].js',
        chunkFilename: '[name].chunk.js'
    },
    // 加载器
    module: {
        // https://doc.webpack-china.org/guides/migrating/#module-loaders-module-rules
        rules: [
            {
                // https://vue-loader.vuejs.org/en/configurations/extract-css.html
                test: /\.vue$/,
                loader: 'vue-loader',
                options: {
                    loaders: {
                        css: 'vue-style-loader!css-loader',
                        less: 'vue-style-loader!css-loader!less-loader'
                    },
                    postLoaders: {
                        html: 'babel-loader'
                    }
                }
            },
            // { test: /\.vue$/, loader: 'vue' },
            // Module build failed: Error: The node API for `babel` has been moved to `babel-core`.
            // https://github.com/babel/babel-loader/blob/master/README.md#the-node-api-for-babel-has-been-moved-to-babel-core
            {
                test: /\.js$/,
                loader: 'babel-loader', exclude: /node_modules/
            },
            {
                test: /\.css$/,
                use: [
                    'style-loader',
                    'css-loader',
                    'autoprefixer-loader'
                ]
            },
            {
                test: /\.less$/,
                use: [
                    'style-loader',
                    'css-loader',
                    'less-loader'
                ]
                // loader: 'style!css!less'
            },
            {
                test: /\.scss$/,
                use: [
                    'style-loader',
                    'css-loader',
                    'sass-loader?sourceMap'
                ]
                // loader: 'style!css!sass?sourceMap'
            },
            { test: /\.(gif|jpg|png|woff|svg|eot|ttf)\??.*$/, loader: 'url-loader?limit=8192'},
            { test: /\.(html|tpl)$/, loader: 'html-loader' }
        ]
    },
    // vue: {
    //     loaders: {
    //         css: ExtractTextPlugin.extract(
    //             "style-loader",
    //             "css-loader?sourceMap",
    //             {
    //                 publicPath: "/test/dist/"
    //             }
    //         ),
    //         less: ExtractTextPlugin.extract(
    //             'vue-style-loader',
    //             'css-loader!less-loader'
    //         ),
    //         js: 'babel'
    //     }
    // },
    resolve: {
        // require时省略的扩展名,如:require('module') 不需要module.js
        extensions: ['.js', '.vue'],
        alias: {
            iview: '../../src/index',
            vue: 'vue/dist/vue.js'
        }
    },
    plugins: [
        // new ExtractTextPlugin({ filename: '[name].css', disable: false, allChunks: true }),
        // new ExtractTextPlugin("[name].css",{ allChunks : true,resolve : ['modules'] }),             // 提取CSS
        // https://doc.webpack-china.org/plugins/commons-chunk-plugin/
        new webpack.optimize.CommonsChunkPlugin({ name: 'vendors', filename: 'vendor.bundle.js' }),
        new HtmlWebpackPlugin({
            inject: true,
            filename: path.join(__dirname, '../test/dist/index.html'),
            template: path.join(__dirname, '../test/index.html') // 模版文件
        })
        // new webpack.optimize.CommonsChunkPlugin('vendors', 'vendors.js'),                           // 提取第三方库
    ]
};