webpack.config.js完整配置

1、完整配置

/*
    webpack配置
*/
//引入路径管理模块
const path = require('path');

//引入html打包插件
const HtmlWebpackPlugin = require('html-webpack-plugin')

//提取css
const MiniCssExtractPlugin = require('mini-css-extract-plugin')
    //压缩css
const OptimizeCssAssetsWebpackPlugin = require('optimize-css-assets-webpack-plugin')


//查看当前是哪种模式
console.log('当前模式', process.env.NODE_ENV);

//各种配置  暴露出去
module.exports = {
    //入口 (单个入口 或多个入口)
    entry: {
        //配置分用样式
        commCss: './src/less/comm/index.js',

        //公用js配置
        dom: './src/js/comm/dom.js',
        http: './src/js/comm/http.js',
        utils: './src/js/comm/utils.js',
        code: './src/lib/captcha/captcha-mini.js',
        iconfont: './src/lib/iconfont/index.js',

        //配置每一个页面的入口
        advertisement: './src/js/advertisement.js',
        register: './src/js/register.js',
        login: './src/js/login.js',
        home: './src/js/home.js',
    },
    //出口
    output: {
        path: path.resolve(__dirname, 'dist'),
        filename: 'js/[name]-[hash:10].js', //多出口 
        publicPath: './'
    },
    //加载器
    module: {
        rules: [
            //css
            {
                test: /\.css$/,
                use: [
                    //配置插件到加载器规则中
                    {
                        loader: MiniCssExtractPlugin.loader,
                        options: {
                            publicPath: '../'
                        }
                    }, 'css-loader',
                    'postcss-loader'
                ]
            },
            //less
            {
                test: /\.less$/,
                use: [{
                        loader: MiniCssExtractPlugin.loader,
                        options: {
                            publicPath: '../'
                        }
                    }, 'css-loader',
                    'postcss-loader',   // 处理css兼容性
                    'less-loader'
                ]
            },
            //css中图像
            {
                test: /\.(jpg|png|gif)$/,
                loader: 'url-loader',
                options: {
                    name: '[hash:10].[ext]',
                    limit: 10 * 1024,
                    outputPath: 'imgs', //把图像打包到指定目录
                    esModule: false
                }
            },
            //html图像
            {
                test: /\.html$/,
                loader: 'html-loader',
            },
            //字体图标
            {
                test: /\.(eot|svg|ttf|woff|woff2)$/, //处理的格式
                loader: 'file-loader',
                options: {
                    name: '[hash:10].[ext]', //输出文件名设置
                    outputPath: 'fonts' //输出目录
                }

            },

            //es6转es5
            {
                test: /\.js$/,
                loader: 'babel-loader',
                exclude: /node_modules/, //不要处理node_modules
            },

        ]
    },
    plugins: [
        //多个html页面
        new HtmlWebpackPlugin({
            template: './src/page/advertisement.html', //把那个html文件打包到dist目录中
            filename: 'advertisement.html', //输出什么名字
            chunks: ['advertisement', 'commCss', 'dom', 'utils'], // 当前页面所需要哪些 模块 模块引入顺序和入口设置时的先后有关
        }),
        new HtmlWebpackPlugin({
            template: './src/page/register.html', //把那个html文件打包到dist目录中
            filename: 'register.html', //输出什么名字
            chunks: ['register', 'commCss', 'dom', 'utils', 'http', 'code']
        }),
        new HtmlWebpackPlugin({
            template: './src/page/login.html', //把那个html文件打包到dist目录中
            filename: 'login.html', //输出什么名字
            chunks: ['login', 'commCss', 'dom', 'utils', 'http']
        }),
        new HtmlWebpackPlugin({
            template: './src/page/home.html', //把那个html文件打包到dist目录中
            filename: 'home.html', //输出什么名字
            chunks: ['home', 'commCss', 'dom', 'utils', 'http', 'iconfont']
        }),
        //提取css
        new MiniCssExtractPlugin({
            filename:   'css/[name].css'  //设置css输出的文件名

        }),
        //压缩css
        new OptimizeCssAssetsWebpackPlugin()
    ],
    //模式   development  production
    mode: process.env.NODE_ENV == 'dev' ? 'development' : 'production',
    //开发服务器
    devServer: {
        contentBase: path.resolve(__dirname,  'dist'),
        publicPath: '/', //服务器根目录
        compress:  true,
          // 启动gzip
            port:  8848,
           // 端口
        open:  true,
          // 自动打开服务
        openPage: 'advertisement.html' //打开哪个页面
    }
}
  • 2
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值