当你的项目体积比较大?你如何做性能优化

在前端开发中,项目体积优化是一个重要的环节,它直接影响到网页的加载速度和用户体验。随着前端项目越来越复杂,引入的依赖也越来越多,如何有效地减少最终打包文件的大小,成为了前端工程师需要面对的挑战。以下是一些常见的前端项目体积优化策略:

1. 代码分割
代码分割(Code Splitting)是一种将代码分成多个小块的技术,然后按需加载这些小块。这样可以减少初始加载的文件大小,加快首屏显示速度。例如,使用Webpack的import()语法可以实现动态导入模块。

// 假设我们有一个很大的模块,不需要在首屏就加载

import(/* webpackChunkName: "huge-module" */ 'huge-module').then(hugeModule => {// 使用hugeModule
});



2. 移除未使用的代码
未使用的代码(Dead Code)不仅增加了项目的体积,还可能引入潜在的bug。通过工具如Webpack的TerserPlugin,可以在构建过程中删除未使用的代码。

const TerserPlugin = require('terser-webpack-plugin');module.exports = {optimization: {minimize: true,minimizer: [new TerserPlugin({terserOptions: {compress: {unused: true,},},})],},
};



3. 压缩资源
资源压缩是减少文件体积的直接方式。对于JavaScript、CSS和HTML,可以使用UglifyJS、CSSNano和HTMLMinifier等工具进行压缩。对于图片,可以使用ImageOptim、TinyPNG等工具进行压缩。

4. 使用Tree Shaking
Tree Shaking是一个通过删除未引用模块中的未使用代码来减少最终bundle大小的过程。在支持ES6模块的打包工具(如Webpack和Rollup)中,Tree Shaking可以自动进行。

// 在Webpack中启用Tree Shaking

module.exports = {mode: 'production', // 生产模式默认启用Tree Shaking
};



5. 优化依赖
项目中的第三方库可能是体积过大的罪魁祸首。可以考虑以下策略:

使用更轻量级的库。
只引入需要的模块,而不是整个库。
使用CDN加载第三方库,减少自身bundle的体积。

6. 使用外部扩展(Externals)
在Webpack中,可以将某些库定义为外部扩展,这意味着这些库不会打包到最终的bundle中,而是在运行时从环境中获取。

module.exports = {// ...externals: {react: 'React','react-dom': 'ReactDOM',},
};



7. 使用持久化缓存
通过将库代码和应用代码分开打包,并为库代码设置较长时间的缓存,可以使得用户在访问网站时只需加载更改过的应用代码。

8. 监控和分析
使用Webpack Bundle Analyzer等工具,定期分析和监控bundle的大小,找出体积过大的原因,并进行相应优化。

const BundleAnalyzerPlugin = require('webpack-bundle-analyzer').BundleAnalyzerPlugin;module.exports = {// ...plugins: [new BundleAnalyzerPlugin(),],
};


9. 懒加载
懒加载是一种优化技术,它将非关键资源的加载推迟到页面需要它们的时候再进行。对于大型网站,懒加载可以显著提高首屏加载速度。在图片或组件上实施懒加载,只有当用户滚动到它们的位置时,才开始加载这些资源。

// 使用React的例子
import React, { Suspense, lazy } from 'react';const LazyComponent = lazy(() => import('./LazyComponent'));function MyComponent() {return (<Suspense fallback={<div>Loading...</div>}><LazyComponent /></Suspense>);
}



10. 预加载和预取
预加载(preload)和预取(prefetch)是两种利用浏览器空闲时间加载资源的技术。预加载用于加载当前页面即将需要的资源,而预取则用于加载可能在未来某个页面中需要的资源。

<!-- 预加载示例 -->
<link rel="preload" href="important-script.js" as="script"><!-- 预取示例 -->
<link rel="prefetch" href="future-script.js" as="script">



11. 避免大型依赖
在选择第三方库时,应当注意它们的大小。有时候,为了一个小功能引入一个大库是不划算的。尽可能寻找轻量级的替代品,或者自行实现所需功能。

12. 多环境构建
针对不同环境(开发、测试、生产)进行不同的构建配置。比如,在开发环境中保留源映射(source maps)以便调试,而在生产环境中移除它们来减少体积。

module.exports = (env) => {return {devtool: env.production ? 'none' : 'source-map',// 其他配置...};
};



13. CSS优化
对于CSS,除了压缩外,还可以采用如PurgeCSS等工具来移除未使用的样式,进一步减少CSS文件的大小。

const PurgecssPlugin = require('purgecss-webpack-plugin');module.exports = {// ...plugins: [new PurgecssPlugin({// 配置项...}),],
};



14. 使用WebP格式
WebP是一种现代图像格式,提供了比传统格式(如JPEG和PNG)更好的压缩效果。在支持WebP的浏览器中使用WebP格式的图片,可以显著减少图片的大小。

15、图片优化
首先,你需要优化你网站上的图片, 用户感觉到的页面加载时长越短,用户体验就越好。我们尤其关注如何优化移动网络中的用户体验,比如网页预加载、减少内容、改变图片格式降低图片尺寸、图片压缩、延迟加载,可以使用tinypng webp 优化图片,提高图片质量。

16、开启GZip压缩


 GZip压缩听被用于减少HTTP请求的大小来缩短响应时间。开启后允许你发送GZip压缩文件而不是HTML文件给浏览器,它将缩短页面等待时间和加载时间。对于服务器,只需在配置文件中来开启GZip压缩即可,前端只需在打包的时候,目标文件的格式为zip。 

17、服务器响应时间
即使网站已经格外优化,但是除非服务器响应时间非常快,否则就不会有什么大的效果。服务器响应时间起着重要的作用。下面是一些提高服务器响应时间的建议。 

有独立的服务器,而不是选择共享/托管服务器。 
提高Web服务器的质量,处理能力。 
移除不必要的插件,只有那些必要的插件,才需要一直保持启用状态。 

18、浏览器缓存


 浏览器具有缓存的功能,可以存储指定的文件,减少HTTP请求,从而提高网站的加载速度。你可以通过在.htaccess文件中设置expires头来开启浏览器缓存,利用下面的代码可以实现: 

19、开启长连接(Keep-Alive)


Keep-Alive头对缩短浏览器和服务器之间的分布式请求的潜伏期是非常重要的,用户通过浏览器请求网页时,浏览器会读取服务器发送的特定的HTML文件,如果请求的页面中包含了外部的CSS和JavaScript文件,浏览器会再次发送独立的请求来获取这些文件,延长页面的加载时间。

20、使用CDN


 内容分发网络(CDN)是位于不同地理位置的服务器组成的网络。每个服务器都拥有所有网站的文件副本。当用户请求文件和网页时,就可以直接从就近的网站服务器获取相应资源(也可以是从负载最小的服务器)。可以使用CDN服务来为网站加速。

21、压缩CSS、JavaScript和HTML文件
通过删除所有不必要的空格和注释,从而减小代码体积,提高页面的加载速度。

22、避免重定向
重定向是对网站访问者的一种极大的消耗,就类似你去一超市买可乐,结果可乐买完了,只能吭哧吭哧跑另一个超市。重定向会消耗额外的时间,降低加载速度。 

23、指定字符集
指定字符集是加速浏览器渲染页面的另一个有用的技巧,可减少浏览器对文件的解析分析步骤。 <meta http-equiv="Content-Type" content="text/html; charset=utf-8">  

24、避免错误请求
当用户在网站上搜索时,收到404或410错误是比较失望的。错误请求会对网站的页面加载速度产生不利影响。建议你无论如何都要避免错误请求,改善用户体验。 

25、丢弃跟踪代码、嵌入视频的元素和分享按钮
很多网站管理员认为使用多个跟踪代码提供嵌入和分享按钮会带给用户更好的体验,实际上这只会给网站增加更多的服务请求。例如,一个iframe会请求一个新页面,这会自动降低网站的加载速度。丢弃这些跟踪代码,可以提高网站加载速度,提升用户体验。

26、异步脚本
还有一个可以提高网站页面速度的超棒选择就是异步加载脚本。如此一来网页负载就并不必依赖于这些异步脚本。在异步模式中,脚本是在后台下载的,不会影响浏览器对页面的渲染和加载。  <script async src="http://XXXXX/script.js"></script> 

27、样式表置顶,脚本置底
将样式表放在顶部有利于页面迅速加载,因为这样可以使得页面慢慢呈现。一般来说,在同一时间,大部分浏览器支持并行下载两个组件(图像、样式和脚本)。但是通常而言,脚本会在并行下载时会阻止其他的下载,直到脚本下载完毕。 

28、JavaScript的延迟解析
为了加载网页,浏览器必须解析所有的标记内容,从而增加了网站的加载时间。通过延迟解析脚本,那么就可以减少初始网站的加载时间了。 <script defer http://XXXXX/script.js"></script>

29、避免阻塞型的JavaScript和CSS
在浏览器呈现网页之前,它首先需要通过解析HTML标记语言来构建一个DOM树。在此过程中,如果遇到了脚本,此过程就会中止,转而先执行脚本,然后才会继续原先的活动。因此建议避免阻塞型的JavaScript,尤其是外部脚本。 

阻塞型JavaScript还会导致网站的延迟。所以不妨推迟加载那些不重要的JavaScript,或者采用异步加载的方式。另一种选择是将这些HTML代码内嵌到网站上,同时需要确保CSS的优化。 

30、优化代码:不使用内联的CSS
内联样式就不能清清楚楚地将内容从设计中剥离开来;还会需要大量的维护工作,给网站管理员带来各种不便,还会进一步增加网页编码的大小。

31、文件分离
网站的文件可以分为CSS、JavaScripts和图像。文件分离虽然并不能直接改善网站的加载时间。但是,这么做可以提高服务器的稳定性,特别是当网站流量突然出现了尖峰的时候。子域也可以用于托管文件,这样可以增加并行下载的数量。

32、尽量减少HTTP请求
还有一种简单的优化网页速度的方法是,减少HTTP请求。当一个网站一下子收到太多的HTTP请求,它的访客就会有响应时间延迟的体验,这不仅增加了CPU使用率也增加了页面的加载时间。那么,又该如何减少HTTP请求?请见以下步骤: 

减少网站上的对象数量。
最小化网站上的重定向数量。
使用CSS Sprites技术(需要的图片内容)。
合并JavaScripts和CSS文件。

最后
前端项目体积优化是一个持续的过程,需要不断地评估、分析和实施最佳实践。通过上述策略的实施,可以显著地减少应用的加载时间,提高用户体验,并可能降低服务器带宽的消耗。这些策略不是孤立使用的,而应该结合项目的具体情况,综合考虑并实施。

随着技术的发展,新的优化技术和工具会不断出现。作为开发者,我们应该保持好奇心,不断探索和尝试,以便为用户提供更快、更流畅的应用体验。

剩下一篇优秀文档参考

写给中高级前端关于性能优化的9大策略和6大指标 | 网易四年实践-CSDN博客

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

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

相关文章

汽车咨询|基于SprinBoot的汽车资讯管理系统设计与实现(源码+数据库+文档)

汽车资讯管理系统目录 基于SprinBoot的汽车资讯管理系统设计与实现 一、前言 二、系统设计 三、系统功能设计 四、数据库设计 五、核心代码 六、论文参考 七、最新计算机毕设选题推荐 八、源码获取&#xff1a; 博主介绍&#xff1a;✌️大厂码农|毕设布道师&#xff…

npm 切换成淘宝源,以及遇到npm 报错如何解决

淘宝源&#xff1a;npm config set registryhttps://registry.npmmirror.com/ 然后再npm下 package-lock.json这个删了 npm i再试一下

MySQL——创建和插入

一、插入数据 INSERT 使用建议; 在任何情况下建议列出列名&#xff0c;在 VALUES 中插入值时&#xff0c;注意值和列的意义对应关系 values 指定的值顺序非常重要&#xff0c;决定了值是否被保存到正确的列中 在指定了列名的情况下&#xff0c;你可以仅对需要插入的列给到…

【已解决】VMware Horizon Client: 无法建立安全加密链路连接

文章目录 问题原因解决方法方法1&#xff1a;在HTTPS拦截中添加VMware忽略列表 (推荐)方法2&#xff1a; 只拦截 浏览器进程的请求 / 取消 HTTPS 拦截&#xff08;如果没有拦截HTTPS的必要 / 只针对浏览器请求&#xff0c;可以使用此方法&#xff09; 当前使用mac 编辑&#xf…

飞书api增加权限

1&#xff0c;进入飞书开发者后台&#xff1a;飞书开放平台 给应用增加权限 2&#xff0c;进入飞书管理后台 https://fw5slkpbyb3.feishu.cn/admin/appCenter/audit 审核最新发布的版本 如果还是不行&#xff0c;则需要修改数据权限&#xff0c;修改为全部成员可修改。 改完…

Matlab与ROS(1/2)---Message(三)

0. 简介 消息是ROS中交换数据的主要容器。主题和服务使用消息在节点之间传输数据。为了标识其数据结构&#xff0c;每条消息都有一个消息类型。例如&#xff0c;来自激光扫描仪的传感器数据通常以sensor_msgs/LaserScan类型的消息发送。每种消息类型标识消息中包含的数据元素。…

类和对象二

一、运算符重载 为了使自定义类型可以使用加减等运算符&#xff0c;CPP提供了一个功能叫运算符重载。 关键字&#xff1a;operator操作符 运算符重载最好定义在类对象里&#xff0c;这也可以避免访问不到私有成员的问题。 代码演示&#xff1a; 在类里定义之后&#xff0c;…

Java常用数据结构与集合

数据结构 数组&#xff1a; 内存地址连续检索效率高(可以通过下标访问成员)增删操作效率低(保证数据越界的问题,需动态扩容)长度固定&#xff0c;扩容的需要新的数组复制或者Arrays类的copyOf方法 链表 内存地址不连续查询快删除慢&#xff0c;因为需要移动指针又分双向链表…

区块链安全-----区块链基础

区块链是一种全新的信息网络架构 &#xff0c;是新一代信息基础设施 &#xff0c;是新型的价值交换方式、 分布式协 同生产机制以及新型的算法经济模式的基础。 区块链技术可以集成到多个领域。 区块链的主要用途 是作为加密货币的分布式总帐。 它在银行 &#xff0c;金融 &…

浏览器工作原理与实践--HTTP/3:甩掉TCP、TLS 的包袱,构建高效网络

前面两篇文章我们分析了HTTP/1和HTTP/2&#xff0c;在HTTP/2出现之前&#xff0c;开发者需要采取很多变通的方式来解决HTTP/1所存在的问题&#xff0c;不过HTTP/2在2018年就开始得到了大规模的应用&#xff0c;HTTP/1中存在的一大堆缺陷都得到了解决。 HTTP/2的一个核心特性是使…

机器学习基础入门(一)(机器学习定义及分类)

机器学习定义 给予计算机无需特意带有目的性编程便有学习能力的算法 深度学习算法 主要有监督学习和非监督学习两类 监督学习&#xff08;supervised learning&#xff09; 定义 1、学习由x映射到y的映射关系 2、主动给予机器学习算法正确示例&#xff0c;算法通过示例来学习…

订单中台架构:打造高效订单管理系统的关键

在现代商业环境下&#xff0c;订单管理对于企业来说是至关重要的一环。然而&#xff0c;随着业务规模的扩大和多渠道销售的普及&#xff0c;传统的订单管理方式往往面临着诸多挑战&#xff0c;如订单流程复杂、信息孤岛、数据不一致等问题。为了应对这些挑战并抓住订单管理的机…

大数据迁移工具开发思路

数据存储MySQL中&#xff0c;迁移到hive中&#xff0c;建立数据仓库&#xff0c;为后期的大数据分析、主题订阅、消息分发提供海量数据支持。 涉及到的服务及中间件版本如下&#xff1a; 1、MySQL&#xff0c;版本&#xff1a;8.0.19 2、Hive&#xff0c;版本&#xff1a;3.0.0…

云计算:Linux 部署 OVS 集群(控制端)实现OpenFlow

目录 一、实验 1.环境 2.Linux 部署 OVS 集群&#xff08;控制端&#xff09; 3.控制端对接服务端OVS网元 4.服务端OVS添加流表 5.服务端删除OVS 二、问题 1. ODL如何查找已安装插件 2.查看流表显示不全 3.如何删除OVS流表 一、实验 1.环境 (1) 主机 表1 宿主机 主…

java包目录命名

包目录命名 config controller exception model common entity enums reponse request repository security service util

Python 全栈系列239 使用消息队列完成分布式任务

说明 在Python - 深度学习系列32 - glm2接口部署实践提到&#xff0c;通过部署本地化大模型来完成特定的任务。 由于大模型的部署依赖显卡&#xff0c;且常规量级的任务需要大量的worker支持&#xff0c;从成本考虑&#xff0c;租用算力机是比较经济的。由于任务是属于超高计…

QA测试开发工程师面试题满分问答11: web前端页面视频组件无法播放如何定位bug

当 web 前端页面的视频组件无法播放时&#xff0c;可以从以下维度进行分析和定位可能的 bug&#xff0c;分析维度包括但不限于&#xff1a;前端功能点、缓存、异常、后端功能点、资源占用、并发、网络等&#xff1a; 前端功能点&#xff1a; HTML5 视频支持&#xff1a;检查视频…

等保测评2.0——网络安全等级保护测评的初步了解

一、什么是网络安全等级保护测评&#xff1f; 二、网络安全等级保护&#xff0c;保护的是什么&#xff1f; 等级保护对象&#xff1a;网络安全等级保护工作直接作用的对象。&#xff08;注&#xff1a;主要包括信息系统、通信网络设施和数据资源等&#xff09; 计算机信息系统…

Qotom Q720G5英特尔赛扬处理器N4000高性价比无风扇迷你电脑5网口软路由防火墙

在数字时代&#xff0c;迷你电脑已经成为高效、灵活的解决方案&#xff0c;无论是个人用户还是企业用户&#xff0c;都能从中受益。Qotom Q720G5 无风扇迷你电脑就是这样一款强大的选择&#xff0c;它不仅可以作为软路由、防火墙和路由器&#xff0c;还有着更多的潜力等待发掘。…

中国手机频段介绍

中国目前有三大运营商&#xff0c;分别是中国移动、中国联通、中国电信&#xff0c;还有一个潜在的运营商中国广电&#xff0c;各家使用的2/3/4G的制式略有不同 中国移动的GSM包括900M和1800M两个频段。 中国移动的4G的TD-LTE包括B34、B38、B39、B40、B41几个频段&#xff0c;…