webpack配置和打包性能优化

devtools/2024/11/26 4:32:21/

文章目录

  • webpack基础配置
    • loader
    • plugin
    • loader 和 plugin 的区别
    • devServer
    • 打包性能优化
        • 1、按需引入组件
        • 2、externals 属性
        • 3、给定文件匹配范围
        • 4、noParse 属性
        • 5、cacheDirectory 缓存属性
        • 6、happyPack 多个子进程并行

webpack_1">webpack基础配置

mode:development:设置webpack的运行模式,开发模式下代码不压缩,生产模式下会启用自动优化;

entry:'./src/index.js':入口文件,打包从此开始;

output:{ filename:'bundle.js' , path:'path.resolve(__dirname,''dist)'}:配置打包后文件输出位置和名称,path.resolve用于获取绝对路径;

module.rules:配置各类文件的处理规则,test属性用户匹配文件路径,use属性指定使用的loader;

loader

loader:用于转换模块的工具。主要用于文件内容的转换。

  • babel-loader处理js文件,将es6+代码转换为es5,通常与@babel/preset-env一起使用;

  • css-loadersaas-loader处理css和sass文件,miniCssExtractPlugin.loader将css提取为单独文件;

  • style-loader将css插入到dom的<style>标签中去;

  • file-loader处理文件(如图片、字体),并返回文件的url;

  • url-loader处理图片文件,8kb以下的图片转为base64,大于8kb的图片则拷贝到输出目录;

  • 自定义loader:实质上是一个函数,接受源文件内容作为输入,并输出处理后的内容。可以通过this.callbak返回结果;

    module.exports = function(source){	//自定义loader:将文件内容中的‘my’替换为‘我的’const result = source.replace(/my/g,'我的');return rusult;
    }
    

plugin

plugin:用于扩展webpack功能的工具,可以在webpack构建过程中执行更复杂的任务,如打包优化、资源管理、环境变量注入等。Plugin主要用于处理构建过程中的各种任务。

  • CleanWebpackPlugin在每次打包前清理输出目录,防止旧文件残留;

  • HtmlWebpackPlugin根据模板生成Html文件,并自动注入打包后的js文件等;

  • MiniCssExtractPlugin将Css提取到单独的文件中;

  • DefinePlugin创建全局变量,在编译时进行替换;

  • TerserPlugin用于压缩js代码,主要在生产环境中使用;

  • 自定义Plugin:plugin是一个类,包含apply方法,apply接受一个complier对象,通过这个对象可以钩入webpack的各个构建阶段;

    class MyPlugin{		//编译完成后输出提示apply(compiler){compiler.hooks.done.tap('MyPlugin',(stats)=>{console.log('编译完成!')})}
    }
    

loader 和 plugin 的区别

  • loader 是文件加载器,操作的是文件,将文件A通过loader转换成文件B,是一个单纯的文件转化过程;能够加载资源文件,并对这些文件进行一些处理,诸如编译、压缩等,最终一起打包到指定的文件中
  • plugin即为插件,是一个扩展器,丰富webpack本身,增强功能 ,针对的是在loader结束之后,webpack打包的整个过程,他并不直接操作文件,而是基于事件机制工作,监听webpack打包过程中的某些节点,执行广泛的任务。 插件赋予了 webpack 各种灵活的功能,例如打包优化、资源管理、环境变量注入等,目的是解决 loader 无法实现的其他事
  • loader 运行在打包文件之前
  • plugins 在整个编译周期都起作用

devServer

Webpack DevServer 是一个开发工具,它可以提供一个简单的 web 服务器,并且能够实时重新加载
contentBase:告诉服务器从哪里提供内容,默认情况下,服务器会使用当前执行目录。
compress:告诉服务器启用 gzip 压缩。
port:指定要监听请求的端口号。
open:告诉服务器自动打开浏览器。
hot:启用模块热替换(Hot Module Replacement)。

打包性能优化

1、按需引入组件

例如引入 element-ui ,用到哪些组件就引哪些

import {Button,Dialog} from 'element-ui';
Vue.use(Button); // 按钮组件
Vue.use(Dialog); // 对话框组件
2、externals 属性

webpackexternals属性,将公共的或不常改动的第三方包名称,配置在属性中,打包时会自动忽略当中的包。具体实现如下:

在 build/webpack.base.conf.js文件中:

module.exports = {externals: {Vue: 'Vue',Axios: 'axios'}
}
// 其中的 key--对应 import Axios名称,value--对应原始方法名称

需要在根目录,index.html 中引入一下

<script src="https://unpkg.com/vue@2.6.11/dist/vue.min.js"></script>
<script src="https://unpkg.com/axios@0.19.2/dist/axios.min.js"></script>
3、给定文件匹配范围

include 规定需要处理的文件有哪些

enclude 排除不需要处理的文件夹

{	test: /\.js$/,loader: 'babel-loader',include: [resolve('src')],exclude: /node_modules/
}
4、noParse 属性

过滤掉不需要解析的文件

{	module: {noParse: /jquery/,rule: [...]}
}
5、cacheDirectory 缓存属性

babel-loader提供了cacheDirectory选项参数,默认为false。

设置空或true时,会利用系统的临时文件夹缓存经过 babel 处理好的模块,对于 rebuild js 有着非常大的性能提升。

{	test: /\.js$/,loader: 'babel-loader?cacheDirectory',include: [resolve('src')],exclude: /node_modules/
}
6、happyPack 多个子进程并行

webpack 在打包过程中,loader 转化js、css、img等文件是同步进行的,一个一个的转换。

happyPack 的原理是,将这些任务分解到多个子进程中,并行执行,执行完成后把结果发送到主进程,从而减少整体的打包时间。


http://www.ppmy.cn/devtools/137021.html

相关文章

推荐文章:FLUI Framework——打造流畅的微软界面体验

推荐文章&#xff1a;FLUI Framework——打造流畅的微软界面体验 FluiFrameworkBringing standardization to Fluent Design by providing easy-to-use styles and controls项目地址:https://gitcode.com/gh_mirrors/fl/FluiFramework 在追求极致用户体验的今天&#xff0c;开…

Github工作流

GitHub 工作流 是一种专门为 GitHub 上的代码协作和版本控制而设计的工作流&#xff0c;它强调通过 **拉取请求&#xff08;Pull Request&#xff0c;PR&#xff09;** 来管理代码的合并和审查。GitHub 工作流通常涉及到使用 **分支** 来进行功能开发和修复&#xff0c;并通过 …

基于物联网设计的人工淡水湖养殖系统(华为云IOT)_253

文章目录 一、前言1.1 项目介绍【1】项目开发背景【2】设计实现的功能【3】项目硬件模块组成【4】设计意义【5】国内外研究现状【6】摘要1.2 设计思路1.3 系统功能总结1.4 开发工具的选择【1】设备端开发【2】上位机开发1.5 参考文献1.6 系统框架图1.7 系统原理图1.8 实物图1.9…

开源动态表单form-create-designer 扩展个性化配置的最佳实践教程

在开源低代码表单设计器 form-create-designer 的右侧配置面板里&#xff0c;field 映射规则为开发者提供了强大的工具去自定义和增强组件及表单配置的显示方式。通过这些规则&#xff0c;你可以简单而高效地调整配置项的展示&#xff0c;提升用户体验。 源码地址: Github | G…

JMeter监听器与压测监控之 InfluxDB

1. 简介 在本文中&#xff0c;我们将介绍如何在 Kali Linux 上通过 Docker 安装 InfluxDB&#xff0c;并使用 JMeter 对其进行性能监控。InfluxDB 是一个高性能的时序数据库&#xff0c;而 JMeter 是一个开源的性能测试工具&#xff0c;可以用于对各种服务进行负载测试和性能监…

神经网络(系统性学习三):多层感知机(MLP)

相关文章&#xff1a; 神经网络中常用的激活函数 神经网络&#xff08;系统性学习一&#xff09;&#xff1a;入门篇 神经网络&#xff08;系统性学习二&#xff09;&#xff1a;单层神经网络&#xff08;感知机&#xff09; 多层感知机&#xff08;MLP&#xff09; 多层感…

【数据结构】【线性表】一文讲完队列(附C语言源码)

队列 队列的基本概念基本术语基本操作 队列的顺序实现顺序队列结构体的创建顺序队列的初始化顺序队列入队顺序队列出队顺序队列存在的问题分析循环队列代码汇总 队列的链式实现链式队列的创建链式队列初始化-不带头结点链式队列入队-不带头节点链式队列出队-不带头结点带头结点…

中标麒麟部署k8sV1.31版本详细步骤

在中标麒麟操作系统上部署 Kubernetes v1.31 的详细步骤如下。这些步骤假定您对 Kubernetes 和 Linux 环境有基本了解&#xff0c;并且中标麒麟系统已正确安装并配置。 环境准备 更新系统并安装必要的软件包 sudo yum update -ysudo yum install -y wget curl vim net-tools…