webpack优化前端框架性能

webpack优化目的

  • webpack优化目的
  • 1. 提升开发体验
      • 提升开发体验使用 SourceMap
  • 2. 提升打包构建速度
      • 提升打包构建速度(开发模式)
      • 提升打包速度 oneOf
      • 提升打包速度 include(包含)/exclude(排除)
      • 提升第二次打包速度 Cache (缓存)
      • 提升打包速度 Thead
  • 3. 减少代码体积
      • 减少代码体积(Tree Shaking)
      • 减少代码体积(Babel)
      • 减少代码体积(Image minimizer)
      • 优化代码的运行性能 (code split)
  • 4.优化代码的运行性能
      • 优化代码的运行性能 (preload / prefetch)
      • 优化代码的运行性能 (network cache)
      • 优化代码的运行性能 (core.js)
      • 优化代码的运行性能 (PWA)

webpack优化目的

  1. 提升开发体验
  2. 提升打包构建速度
  3. 减少代码体积
  4. 优化代码运行性能

1. 提升开发体验

提升开发体验使用 SourceMap

  1. 问题:正常情况下,开发环境不输出dist 文件 直接保存在内存中,浏览器控制台source中可以看到,
    但是报错提示行数不正确,它会以打包后的行数进行提示

  2. 解释:sourceMap 可以生成源代码与打包代码一一映射的关系,方便找到出错源行数

  3. 使用方案:有两种模式,cheap-module-source-map | source-map
    source-map 行列都提示,运行慢 c-m-s-m 提示行出错
    这里有歧义:视频讲解生产用s-m 开发用 c-m-s-m
    实际可能用 生产:禁用 开发:用c-m-s-m

  4. 正常使用:在webpack配置文件中 devtool:“cheap-module-source-map” 直接添加一句即可

2. 提升打包构建速度

提升打包构建速度(开发模式)

  1. HotModuleReplacement (HMR热模块替换) devServer 中 hot:true(W5默认值) !!!生产环境不推荐使用

  2. 注意:js文件不会热替换,如果需要可以在main.js中写上
    //判断是否支持HMR功能,如果支持js也热替换
    if(module.hot){
    module.hot.accept(./js/count)
    }

  3. 在react 和 vue 中 vue框架内部集成了 React Hot Loader 来解决
    react hot loader 下载之后 添加到babel-loader的option选项中的plugins中,并在根组件使用,使用方法chatgpt

提升打包速度 oneOf

  1. 使用 :webpack配置文件中 创建一个对象oneOf包裹所有的loader,
  2. 原理: 打包时oneOf只使用一个loader 速度更快,不用遍历所有的loader

提升打包速度 include(包含)/exclude(排除)

  1. 使用 :include:path.resolve(__dirname,“…/src”) __dirname当前执行脚本的绝对路径
    exclude:“node_modules”
  2. 注意:主要针对js 文件babel 和 eslint

提升第二次打包速度 Cache (缓存)

  1. 原理:js文件每次打包都要经过eslint检查,babel编译,可以对其缓存
  2. 使用:在babel的option选项配置中 开启缓存 eslint 插件中也开启缓存

提升打包速度 Thead

  1. 原理:对于js文件的处理主要是 eslint、babel、teser(内部供生产环境压缩js文件使用)三个工具,通过使用Thead可以开启电脑多进程同时处理js文件
  2. 注意:在特别耗时的操作中使用,因为每个进程的启动大约有600ms左右开销
  3. 使用:
    1. 获取cpu的核数,每个电脑不一样
    node.js核心模块直接使用
    const os = require(“os”)
    cpu核数
    const threads = os.cpus().length
    2. 安装 npm i thread-loader -D
    3. 在babel-loader 和 eslint插件中开启多进程
    4. 使用TeserWebpackPlugin(无需下载)开启多进程压缩js文件

3. 减少代码体积

减少代码体积(Tree Shaking)

  1. Tree Shaking 不需要配置webpack默认开启
  2. 作用:旨在移除未使用的代码(未引用的模块、函数、变量等),从而减少最终打包后的文件大小。

减少代码体积(Babel)

  1. 原理:babel会为编译的每个文件都插入辅助代码,使代码的体积过大
    Babel对一些公共方法使用了非常小的辅助代码,比如extend. 默认情况下会被添加到每一个需要它的文件中。
    你可以使用runtime将这些辅助代码作为一个独立模块,来避免重复引入。
  2. 介绍:runtime 禁用了babel自动对每个文件的runtime注入,而是引入;
    并且使所有的辅助代码从这里引用
  3. 使用: npm i @babel/plugin-transform-runtime -D
    插件放到babel中

减少代码体积(Image minimizer)

  1. 原理:打包时对图片进行压缩
  2. 使用: npm i image-minimizer-webpack-plugin imagemin -D
    无损压缩:npm install imagemin-gifsicle imagemin-jpegtran imagemin-optipng imagemin-svgo -D
    有损压缩:npm install imagemin-gifsicle imagemin-mozjpeg imagemin-pngquant imagemin-svgo -D
  3. 注意:有损、无损安装一个即可,这里在安装的时候可能会安装不上,使用cnpm单独安装imagemin-gifsicle

优化代码的运行性能 (code split)

  1. 原理:打包时会将所有的js文件打包到一个文件中,code split 可以
    将打包生成的文件进行分割,生成多个js文件,需要那个文件就加载那个文件

  2. 使用:见wpcodeSplitTest,webpack配置 无需下载

  3. 在动态加载文件时,会单独进行打包,当需要时自动加载

4.优化代码的运行性能

优化代码的运行性能 (preload / prefetch)

  1. 原理: 我们在使用split之后,代码按需加载会卡顿。
    preload :告诉浏览器立即加载资源(优先级高,只加载当前页面)
    prefetch :告诉浏览器在空闲时间加载 (可以加载当前页面。也可以加载其他页面)
    他们都只会加载资源,并不执行
    都有缓存

  2. 缺点:兼容性差,preload不兼容ie,prefetch(60%)不兼容safri 建议使用preload(92%浏览器支持)

  3. 使用: npm i -D preload-webpack-plugin
    const PreloadWebpackPlugin = require(“preload-webpack-plugin”)
    放到htmlplugin后面,
    new PreloadWebpackPlugin()

优化代码的运行性能 (network cache)

  1. 原理 :当缓存文件发生变化,一般所有都更新,加上这个只更新修改的文件,其他缓存文件不变
  2. 使用 :
    runtimeChunk: {
    name: (entrypoint) => runtime~${entrypoint.name}.js
    }

优化代码的运行性能 (core.js)

  1. 原理: 我们使用babel打包时能对es6进行编译转换,但是promise、async等无法编译,放到一些浏览器就会有兼容性问题,直接报错

  2. 概念:core.js专门用来做es6以上的polyfill(补丁)

  3. 使用:
    npm安装
    修改main.js
    import “core-js”; 会有一个问题是打包出来的文件比较大

     所以我们可以根据需要的兼容引入 import "core-js/es/promise"更好的方法在babel.config.js中配置presets: [["@babel/preset-env",{useBuiltIns: "usage",  // 按需引入corejscorejs: 3,},],],
    

优化代码的运行性能 (PWA)

渐进式网络应用程序 离线时也能继续运行功能(正常情况下不可以)

使用:插件webpack Workbox 见官网
npm install workbox-webpack-plugin --save-dev
const WorkboxPlugin = require(‘workbox-webpack-plugin’);
plugins: [
new HtmlWebpackPlugin({
title: ‘Output Management’,
title: ‘Progressive Web Application’,
}),
new WorkboxPlugin.GenerateSW({
// 这些选项帮助快速启用 ServiceWorkers
// 不允许遗留任何“旧的” ServiceWorkers
clientsClaim: true,
skipWaiting: true,
}),
],

在main.js 添加if ('serviceWorker' in navigator) {

window.addEventListener(‘load’, () => {
navigator.serviceWorker.register(‘/service-worker.js’).then(registration => {
console.log('SW registered: ', registration);
}).catch(registrationError => {
console.log('SW registration failed: ', registrationError);
});
});
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/13204.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

爬虫-requests-cookie登录古诗文网

一、前言 1、requests简介 requests是一个很实用的Python HTTP客户端库,爬虫和测试服务器响应数据时经常会用到,它是python语言的第三方的库,专门用于发送HTTP请求,使用起来比urllib更简洁也更强大。 2、requests的安装 pip i…

电脑选睡眠、休眠还是关机?

关机 这是大家最熟悉的。关机时,系统首先关闭所有运行中的程序,然后关闭系统后台服务。随后,系统向主板请求关机,主板断开电源的供电使能,让电源切断对绝大多数设备的供电(只剩一些内部零件仍会维持电源供应…

华为刷题:HJ3明明随机数

import java.util.Scanner;// 注意类名必须为 Main, 不要有任何 package xxx 信息 public class Main {public static void main(String[] args) {Scanner scan new Scanner(System.in);int N scan.nextInt();int[] arr new int[N];for (int i 0; i < N; i) {int n sca…

Materials - UE5中的PivotPainter

个人学习笔记的归档和发表&#xff1b;文中所有案例都来自官方的ContentExample中的PivotPainter相关关卡&#xff1b; 可以使用3DS Max Script中的脚本&#xff08;Pivot Painter&#xff09;对模型进行处理&#xff0c;让每个Element都有自己的Pivot Point&#xff0c;来方便…

PostgreSQL 简洁、使用、正排索引与倒排索引、空间搜索、用户与角色

PostgreSQL使用 PostgreSQL 是一个免费的对象-关系数据库服务器(ORDBMS)&#xff0c;在灵活的BSD许可证下发行。PostgreSQL 9.0 &#xff1a;支持64位windows系统&#xff0c;异步流数据复制、Hot Standby&#xff1b;生产环境主流的版本是PostgreSQL 12 BSD协议 与 GPL协议 …

SQL server 文件占用硬盘过大 日志 读写分离同步文件过大清理 DBCC收缩数据库 分发数据库distribution收缩

一顿操作猛如虎 又省出好几十G硬盘空间 小破站又能蹦跶了 目标&#xff1a;实例库日志压缩清理,分发数据库压缩清理 采用SQL 脚本收缩数据库 截断事务日志 backup log [数据库名] with no_log收缩数据库 dbcc shrinkdatabase ([数据库名]) 4.以上操作都不行的话&#xff0…

物联网场景中的边缘计算解决方案有哪些?

在物联网场景中&#xff0c;边缘计算是一种重要的解决方案&#xff0c;用于在物联网设备和云端之间进行实时数据处理、分析和决策。HiWoo Box作为工业边缘网关设备&#xff0c;具备边缘计算能力&#xff0c;包括单点公式计算、Python脚本编程以及规则引擎&#xff0c;它为物联网…

华为云NFS使用API删除大文件目录

最近在使用华为云SFS时&#xff0c;如果一个目录存储文件数超过100W&#xff0c;执行 “rm -rf path”时&#xff0c;存在删不动的情况&#xff0c;可以使用华为云API接口&#xff0c;执行异步删除。 华为官网&#xff1a; 删除文件系统目录_弹性文件服务 SFS_API参考_SFS Tu…

高效率,38V最大输入单电感同步升/降稳压器SYV939C

SYV939是一种高压同步降压-升压转换器。该器件工作在4V至28V的宽输入电压范围内&#xff0c;具有10max平均电感电流能力。四个集成的低RDS(ON)开关最大限度地减少了传导损耗。 SYV939c包括完整的保护功能&#xff0c;如输出过流/短路保护&#xff0c;过压保护和热停机&#xff…

Eclipse memory analyzer 分析GC dump日志定位代码问题

1、问题描述&#xff1a; 使用命令 jstat -gcutil [pid] 查看JVM GC日志&#xff0c;发现生产系统频繁FullGC&#xff0c;大概几分钟一次&#xff0c;而且系统响应速度变慢很多 再使用 free -g 查看服务器内存全部占用&#xff0c;猜测是内存溢出了 2、导出dump日志 jmap -du…

【C++ 程序设计】实战:C++ 变量实践练习题

目录 01. 变量&#xff1a;定义 02. 变量&#xff1a;初始化 03. 变量&#xff1a;参数传递 04. 变量&#xff1a;格式说明符 ① 占位符 “%d” 改为格式说明符 “%llu” ② 占位符 “%d” 改为格式说明符 “%f” 或 “%e” 05. 变量&#xff1a;字节数统计 06. 变量&a…

【Javalin 】Javalin Kotlin/Java 轻量级 REST API 库

Javalin 旨在为 Kotlin 和 Java 提供一个易用的轻量级 REST API 库。这个 REST API 易于使用&#xff0c;API 也非常的流畅。 Javalin 主要有以下的特点&#xff1a; 易用&#xff1a;不用提前学习任何概念就可以开始使用 一致的 API&#xff1a;所有的处理程序和映射器在 Co…

数据库介绍-非关系型数据库

文章目录 非关系型数据库NoSQL的分类键值对存储数据库Redis 列存储数据库文档存储数据库MongoDB 图形数据库搜索引擎数据库 非关系型数据库 NoSQL(NoSQL Not Only SQL )&#xff0c;意即“不仅仅是SQL”&#xff0c;泛指非关系型的数据库。 NoSQL 不依赖业务逻辑方式存储&…

Redis学习

1.数据类型 Redis支持五种数据类型&#xff0c;分别是String&#xff08;字符串&#xff09;、hash&#xff08;哈希&#xff09;、list&#xff08;列表&#xff09;、set&#xff08;集合&#xff09;、zset&#xff08;有序集合&#xff09;。 1.1 String&#xff08;字符…

无涯教程-jQuery - html( )方法函数

html(val)方法获取第一个匹配元素的html内容(innerHTML)。此属性在XML文档上不可用。 html( ) - 语法 selector.html( ) html( ) - 示例 以下是一个简单的示例&#xff0c;简单说明了此方法的用法- <html><head><title>The jQuery Example</title>…

Android性能优化之Thread native层源码分析(InternalError/Out of memory)

近期处理Bugly上OOM问题&#xff0c;很多发生在Thread创建启动过程&#xff0c;虽然最后分析出是32位4G虚拟内存不足导致&#xff0c;但还是分析下Java层Thread 源码过程&#xff0c;可能会抛出的异常InternalError/Out of memory。 Thread报错堆栈&#xff1a; Java线程创建…

无涯教程-jQuery - serialize( )方法函数

serialize()方法将一组输入元素序列化为数据字符串。 serialize( ) - 语法 $.serialize( ) serialize( ) - 示例 假设无涯教程在serialize.php文件中具有以下PHP内容- <?php if( $_REQUEST["name"] ) {$name$_REQUEST[name];echo "Welcome ". $na…

递归:一个图教学会递归原理

递归的特点 实际上&#xff0c;递归有两个显著的特征,终止条件和自身调用: 自身调用&#xff1a;原问题可以分解为子问题&#xff0c;子问题和原问题的求解方法是一致的&#xff0c;即都是调用自身的同一个函数。终止条件&#xff1a;递归必须有一个终止的条件&#xff0c;即不…

被泼冷水后,谁能超越微服务?

历史总会重演。一切刚过去的&#xff0c;又会被重新提起。开源项目Codename One的联合创始人Shai&#xff0c;曾是Sun Microsystems开源LWUIT项目的共同作者&#xff0c;参与了无数开源项目。作为最早一批Java开发者&#xff0c;最近感慨道&#xff1a;单体&#xff0c;又回来了…

【matlab】机器人工具箱快速上手-动力学仿真(代码直接复制可用)

动力学代码&#xff0c;按需修改参数 各关节力矩-关节变量的关系曲线&#xff1a; %%%%%%%%SCARA机器人仿真模型 l[0.457 0.325]; L(1) Link(d,0,a,l(1),alpha,0,standard,qlim,[-130 130]*pi/180);%连杆1 L(2)Link(d,0,a,l(2),alpha,pi,standard,qlim,[-145 145]*pi/180);%连…