webpack.prod.js(webpack生产环境配置文件)

生产环境:只打包不运行本地服务器


对于在config目录下的webpack.prod.js

1.在根目录下运行

npx webpack --config ./config/webpack.prod.js

2.在package.json文件中配置

"build":"npx webpack --config ./config/webpack.prod.js"

javascript 复制代码
const path =require('path')
const ESLintPlugin = require('eslint-webpack-plugin');
const HtmlWebpackPlugin = require('html-webpack-plugin');
module.exports={
    //入口
    //输出
    //加载器
    //插件
    //模式
    entry:"./src/main.js",//相对路径
    output:{
        //文件的输出路径 __dirname:当前文件的文件夹目录
        path:path.resolve(__dirname,"../dist"),//绝对路径 path是所有文件的输出路径
        //入口文件打包输出的文件名
        filename:"static/js/main.js",
        clean: true,//每次打包前清理上一次打包的内容
    },
    module:{
        rules:[
            //loader的配置
            {
                test: /\.css$/, //只检测.css文件
                use: [//执行顺序从右到左,从下到上
                'style-loader', //将js中的css通过创建style标签添加到html文件中生效
                'css-loader'],//将css资源编译成common.js到webpack中
              },
              {
                test: /\.less$/i,
                //loader:"xxx" 只能使用一个loader use可以使用多个
                use: [
                  // compiles Less to CSS
                  'style-loader',
                  'css-loader',
                  'less-loader',
                ],
              },
              {
                test: /\.s[ac]ss$/i,
                use: [
                  // 将 JS 字符串生成为 style 节点
                  'style-loader',
                  // 将 CSS 转化成 CommonJS 模块
                  'css-loader',
                  // 将 Sass 编译成 CSS
                  'sass-loader',
                ],
              },
              {
                test: /\.styl$/,
                // loader: 'stylus-loader', // 将 Stylus 文件编译为 CSS
                use: [
                  // compiles Less to CSS
                  'style-loader',
                  'css-loader',
                  'stylus-loader',
                ],

              },
              {
                test: /\.(png|jpe?g|gif|webp|svg)$/,
                type: 'asset',
                parser: {
                  dataUrlCondition: {
                    //小于10kb的图片转base64 减少请求数量 但是体积会大一点
                    maxSize: 10 * 1024 // 10kb
                  }
                },
                generator: {
                  filename: 'static/images/[hash:10][ext][query]'
                  //图片命名有点长 [hash:10]只取十位
                }
              },{
                test: /\.(ttf|woff2?)$/,
                type: 'asset/resource',
                generator: {
                  filename: 'static/fonts/[hash:10][ext][query]'
                }
              },{
                test: /\.(mp3|mp4|avi)$/,
                type: 'asset/resource',
                generator: {
                  filename: 'static/media/[hash:10][ext][query]'
                }
              }, {
                test: /\.js$/,
                exclude: /(node_modules)/,//排除node_modules中的js文件
                use: {
                  loader: 'babel-loader',
                  // options: {
                  //   presets: ['@babel/preset-env'],
                  // },
                },
              }
        ]
    },
    //插件需要引用才能使用
    plugins:[
        //插件的配置
        new ESLintPlugin({
          //检测哪些文件
          context: path.resolve(__dirname,'../src'),
        }),
        new HtmlWebpackPlugin({
          //模版 新的html文件结构与原来一致 会自动引入打包的资源
          template:path.resolve(__dirname,'../public/index.html')
        })
    ],
    //模式
    mode:"production",
}
相关推荐
0思必得022 分钟前
[Web自动化] Selenium处理动态网页
前端·爬虫·python·selenium·自动化
东东5161 小时前
智能社区管理系统的设计与实现ssm+vue
前端·javascript·vue.js·毕业设计·毕设
catino1 小时前
图片、文件的预览
前端·javascript
2501_920931702 小时前
React Native鸿蒙跨平台实现推箱子游戏,完成玩家移动与箱子推动,当所有箱子都被推到目标位置时,玩家获胜
javascript·react native·react.js·游戏·ecmascript·harmonyos
layman05283 小时前
webpack5 css-loader:从基础到原理
前端·css·webpack
半桔3 小时前
【前端小站】CSS 样式美学:从基础语法到界面精筑的实战宝典
前端·css·html
AI老李3 小时前
PostCSS完全指南:功能/配置/插件/SourceMap/AST/插件开发/自定义语法
前端·javascript·postcss
_OP_CHEN3 小时前
【前端开发之CSS】(一)初识 CSS:网页化妆术的终极指南,新手也能轻松拿捏页面美化!
前端·css·html·网页开发·样式表·界面美化
啊哈一半醒3 小时前
CSS 主流布局
前端·css·css布局·标准流 浮动 定位·flex grid 响应式布局
PHP武器库3 小时前
ULUI:不止于按钮和菜单,一个专注于“业务组件”的纯 CSS 框架
前端·css