webpack生产模式配置

news/2024/11/17 1:58:51/

一、生产模式和开发模式介绍

生成模式(production mode)是指在开发完成后将代码部署到生产环境中运行的模式,通常需要进行代码压缩、优化、合并,以减少文件大小和请求次数,提高页面加载速度和运行效率。

开发模式(development mode)则是指在开发过程中使用的模式,通常需要对代码进行调试、热更新等操作,以提高开发效率和代码质量。在开发模式下,通常不需要进行代码优化和压缩,可以保留源代码的完整性,以便于调试和排查问题

二、生产模式准备

1. 重改目录结构

在前面的章节中我们一直配置的都是webpack.config.js,其实这些所有的配置都是为我们开发环境服务的,现在我们需要打个生产模式下的包,那么我们就需要两个配置文件,我们更改文件结构如下:

├── webpack-test (项目根目录)├── config (Webpack配置文件目录)│    ├── webpack.dev.js(开发模式配置文件)│    └── webpack.prod.js(生产模式配置文件)├── node_modules (下载包存放目录)├── src (项目源码目录,除了html其他都在src里面)│    └── 略├── public (项目html文件)│    └── index.html├── .eslintrc.js(Eslint配置文件)├── babel.config.js(Babel配置文件)└── package.json (包的依赖管理配置文件)

新增config目录,将以前的webpack.config.js重命名为webpack.dev.js并移动到config目录下,在新建一个webpack.prod.js文件,专门用来处理生成模式打包资源。

2. 修改 webpack.dev.js

  • webpack.dev.js调整后的代码:
// Node.js的核心模块,专门用来处理文件路径
const path = require("path");const ESLintWebpackPlugin = require("eslint-webpack-plugin"); // 引入 ESLint 插件
const HtmlWebpackPlugin = require("html-webpack-plugin"); // 引入 html-webpack-plugin 插件module.exports = {// 入口// 相对路径和绝对路径都行entry: "./src/main.js",// 输出output: {// path: 文件输出目录,必须是绝对路径// path.resolve()方法返回一个绝对路径// __dirname 当前文件的文件夹绝对路径path: undefined,// filename: js文件输出文件名filename: "js/main.js",clean: true, // 自动将上次打包目录资源清空},// 加载器module: {rules: [{// 用来匹配 .css 结尾的文件test: /\.css$/,// use 数组里面 Loader 执行顺序是从右到左use: ["style-loader", "css-loader"],},{// 用来匹配.less结尾的文件test: /\.less$/,use: ["style-loader", "css-loader", "less-loader"],},{test: /\.s[ac]ss$/,use: ["style-loader", "css-loader", "sass-loader"],},{// 用来匹配图片文件test: /\.(png|jpe?g|gif|webp)$/,type: "asset",parser: {dataUrlCondition: {maxSize: 10 * 1024, // 小于10kb的图片会被base64处理},},generator: {// 将图片文件输出到 images 目录中// 将图片文件命名 [hash:8][ext][query]// [hash:8]: hash值取8位// [ext]: 使用之前的文件扩展名// [query]: 添加之前的query参数filename: "images/[hash:8][ext][query]",},},{test: /\.(ttf|woff2?|map4|map3|avi)$/,type: "asset/resource", // 以文件资源的形式输出generator: {filename: "media/[hash:8][ext][query]", // 输出到media目录中},},{test: /\.m?js$/, // 转译哪些文件exclude: /(node_modules|bower_components)/, // 排除哪些文件夹中的js文件不用转译// use: {loader: 'babel-loader',//   options: {//     presets: ['@babel/preset-env'] // 添加预设,转译js文件//   }// }}],},// 插件plugins: [new ESLintWebpackPlugin({// 指定检查文件的根目录context: path.resolve(__dirname, "../src"),}),new HtmlWebpackPlugin({// 以 public/index.html 为模板创建文件// 新的html文件有两个特点:1. 内容和源文件一致 2. 自动引入打包生成的js等资源template: path.resolve(__dirname, "../public/index.html"),}),],// 开发服务器devServer: {host: "localhost", // 启动服务器域名port: "8888", // 启动服务器端口号open: true, // 是否自动打开浏览器},// 模式mode: "development", // 开发模式
};

3. 运行开发模式的指令:

npx webpack serve --config ./config/webpack.dev.js

–config 后面跟的就是npx webpack serve 的配置文件目录

运行效果如图:
在这里插入图片描述
在这里插入图片描述
可以看到还是正常运行了

4. 修改webpack.prod.js

// Node.js的核心模块,专门用来处理文件路径
const path = require("path");const ESLintWebpackPlugin = require("eslint-webpack-plugin"); // 引入 ESLint 插件
const HtmlWebpackPlugin = require("html-webpack-plugin"); // 引入 html-webpack-plugin 插件module.exports = {// 入口// 相对路径和绝对路径都行entry: "./src/main.js",// 输出output: {// path: 文件输出目录,必须是绝对路径// path.resolve()方法返回一个绝对路径// __dirname 当前文件的文件夹绝对路径path: path.resolve(__dirname, "../dist"),// filename: js文件输出文件名filename: "js/main.js",clean: true, // 自动将上次打包目录资源清空},// 加载器module: {rules: [{// 用来匹配 .css 结尾的文件test: /\.css$/,// use 数组里面 Loader 执行顺序是从右到左use: ["style-loader", "css-loader"],},{// 用来匹配.less结尾的文件test: /\.less$/,use: ["style-loader", "css-loader", "less-loader"],},{test: /\.s[ac]ss$/,use: ["style-loader", "css-loader", "sass-loader"],},{// 用来匹配图片文件test: /\.(png|jpe?g|gif|webp)$/,type: "asset",parser: {dataUrlCondition: {maxSize: 10 * 1024, // 小于10kb的图片会被base64处理},},generator: {// 将图片文件输出到 images 目录中// 将图片文件命名 [hash:8][ext][query]// [hash:8]: hash值取8位// [ext]: 使用之前的文件扩展名// [query]: 添加之前的query参数filename: "images/[hash:8][ext][query]",},},{test: /\.(ttf|woff2?|map4|map3|avi)$/,type: "asset/resource", // 以文件资源的形式输出generator: {filename: "media/[hash:8][ext][query]", // 输出到media目录中},},{test: /\.m?js$/, // 转译哪些文件exclude: /(node_modules|bower_components)/, // 排除哪些文件夹中的js文件不用转译// use: {loader: 'babel-loader',//   options: {//     presets: ['@babel/preset-env'] // 添加预设,转译js文件//   }// }}],},// 插件plugins: [new ESLintWebpackPlugin({// 指定检查文件的根目录context: path.resolve(__dirname, "../src"),}),new HtmlWebpackPlugin({// 以 public/index.html 为模板创建文件// 新的html文件有两个特点:1. 内容和源文件一致 2. 自动引入打包生成的js等资源template: path.resolve(__dirname, "../public/index.html"),}),],// 模式mode: "production", // 生产模式
};

运行生产模式的指令:

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

在这里插入图片描述
如上图,我们的dist目录下又有内容啦,并且index.htmljs/main.js中的代码都是被压缩过的。

5. 配置运行指令

为了方便运行不同模式的指令,我们将指令定义在 package.jsonscripts 里面


// package.json
{// 其他省略"scripts": {"start": "npm run dev","dev": "npx webpack serve --config ./config/webpack.dev.js","build": "npx webpack --config ./config/webpack.prod.js"}
}

以后启动指令:

  • 开发模式:npm startnpm run dev
  • 生产模式:npm run build

好啦 到目前为止,这是不是有点脚手架的感觉了


http://www.ppmy.cn/news/363476.html

相关文章

一个爆款小程序的复盘

在社交网络的用户行为中,表情和图像素材处理一直是非常强烈的需求所在,旧文 今天聊聊表情包 里面点到为止,不敢说的太多。 那么从PC时代,到移动APP时代,到微信时代,这一诉求从未降温,但你理解诉…

拳王公社:网络操盘手必备的400款新媒体运营工具大全!

今天拳王将为大家免费分享一份『硬核干货』! 作为扎根于互联网的网创人,我们在操作副业项目过程中,必须要借助一些能提升我们工作效率的工具,这些工具你不一定全部都需要去运用,把最重要的几个运用熟练便可&#xff0…

网页设计公众号相关资源网站

网页设计公众号相关资源网站 查看公众号文章的工具 http://chuansong.me/ 交互、UI 设计资源整理:链接: https://pan.baidu.com/s/1eSvLqwE 密码: 4wxc PS,AI,Sketch工具教程集结:链接: https://pan.baidu.com/s/1nva8owp 密码: 6…

全网最详细chatgpt提示词,纯手工整理(二)

文章目录 学习助手模仿知乎的风格思维导图PPT制作小说家今日运势周公解梦抖音文案助手好评神器快速生成小红书种草文赞美大师您需要我给哪一部电影写影评?甜蜜的Ai女友数学历史老师歌曲推荐人创业技术律师书面作品的标题生成器产品经理销售员提交消息生成器首席执行官图表生成…

hash算法详解

散列算法(Hash Algorithm),又称哈希算法,杂凑算法,是一种从任意文件中创造小的数字「指纹」的方法。与指纹一样,散列算法就是一种以较短的信息来保证文件唯一性的标志,这种标志与文件的每一个字…

Axure RP教程_编程入门自学教程_菜鸟教程-免费教程分享

教程简介 Axure RP是一款专业的快速原型设计工具。Axure(发音:Ack-sure),代表美国Axure公司;RP则是Rapid Prototyping(快速原型)的缩写。 Axure RP是美国Axure Software Solution公司旗舰产品…

优思学院|什么是六西格玛?一文解答你对六西格玛最常见的疑问

什么是六西格玛? 六西格玛(Six Sigma)是一种管理方法和质量改进体系,旨在减少组织过程中的变异性,提高业务绩效,并实现客户满意度的持续提升。它是由美国Motorola公司在20世纪80年代发展起来的&#xff0c…

推荐款一直免费的企业电脑监控软件

目前国内上网管理软件、网络控制软件种类繁多,如何选择适合的网管软件呢?目前网络上大多数都是一些过度营销的推广文章,目的是推销自己的软件,让用户浪费时间与金钱,这里推荐一款免费的企业电脑监控软件——“易掌电脑…