美文网首页
webpack配置1

webpack配置1

作者: 日出丶 | 来源:发表于2021-03-03 11:43 被阅读0次
//html-webpack-plugin可以生成一个html,并且自动引入js、css
var HtmlWebpackPlugin = require('html-webpack-plugin')
//清除webpack打包的文件
var { CleanWebpackPlugin } = require('clean-webpack-plugin')
//从js、抽离css文件使用link引入
var MiniCssExtractPlugin = require('mini-css-extract-plugin')
//压缩css文件
var OptimizeCSSAssetsPlugin = require('optimize-css-assets-webpack-plugin')

var path = require('path')
module.exports = {
        //打包的入口文件
    entry: ['./src/js/index.js'],
        //输出的打包文件目录,以及文件名,
    output: {
        filename: '[name].js',
        path: __dirname + '/dist',
    },
      //各种loader,处理文件,注:编译是从后向前,比如scss文件,
      //先用sass-loader,->postcss-loader处理css兼容,css-loader处理css问题,引入问题:例子:require("xx.scss")因为处理css-loader是在js模块里面的,所以MiniCssExtractPlugin.loader抽离css使用link方式引入
    module: {
        rules: [
            {
                test: /\.scss$/,
                use: [MiniCssExtractPlugin.loader, 'css-loader', 'postcss-loader', 'sass-loader'],
            },
            {
                test: /\.css$/,
                use: [MiniCssExtractPlugin.loader, 'css-loader', 'postcss-loader', 'sass-loader'],
            },
            {
                test: /\.m?js$/,
                exclude: /node_modules/,
                use: {
                    loader: 'babel-loader',
                    options: {
                        presets: ['@babel/preset-env'],
                    },
                },
            },
        ],
    },
        //需要安装webpack-dev-server,才有此项配置,open是否浏览器打开,host设置当前host,port当前端口,contentBase指定从哪里获取静态文件,但是dist并不生成文件
    devServer: {
              
        contentBase: path.join(__dirname, 'dist'),
        compress: true,
        open: true,
        host: 'my.xx.xx.com',
        port: 80,
    },
    plugins: [
        new HtmlWebpackPlugin({
            title: 'index',
            // 解析以后生成到的文件路径和名称,目录相对于webpack.output.path 来进行设置
            filename: 'index.html',
            // 指定原始的html文件(模板文件)
            template: './html/index.html',
        }),
        new CleanWebpackPlugin(),
        new MiniCssExtractPlugin({
            filename: 'css/[name].[hash:8].css',
            chunkFilename: 'css/[id].[hash:8].css',
        }),
        new OptimizeCSSAssetsPlugin({}),
    ],
    devtool: 'source-map',
}

相关文章

网友评论

      本文标题:webpack配置1

      本文链接:https://www.haomeiwen.com/subject/mmqqqltx.html