当前位置: 首页 > article >正文

【架构实战】前端性能优化:SSR/懒加载/代码分割

一、前端性能优化概述前端性能直接影响用户体验关键指标- FCP首次内容绘制1.8s- LCP最大内容绘制2.5s- TTI可交互时间❤️.8s- FID首次输入延迟100ms## 二、SSR服务端渲染### 1. Next.js SSRjavascript// pages/index.js - 服务端渲染export async function getServerSideProps() { const data await fetch(https://api.example.com/data).then(r r.json()); return { props: { data } };}export default function Home({ data }) { return ( div h1{data.title}/h1 ProductList products{data.products} / /div );}### 2. 静态生成SSGjavascript// pages/products/[id].js - 静态生成export async function getStaticPaths() { const products await fetchProducts(); return { paths: products.map(p ({ params: { id: p.id } })), fallback: blocking // 新页面在首次访问时生成 };}export async function getStaticProps({ params }) { const product await fetchProduct(params.id); return { props: { product }, revalidate: 60 // 每60秒重新生成 };}## 三、懒加载### 1. 路由懒加载javascript// React Router懒加载import { lazy, Suspense } from react;import { BrowserRouter, Routes, Route } from react-router-dom;const Home lazy(() import(./pages/Home));const Product lazy(() import(./pages/Product));const Cart lazy(() import(./pages/Cart));function App() { return ( BrowserRouter Suspense fallback{Loading /} Routes Route path/ element{Home /} / Route path/product/:id element{Product /} / Route path/cart element{Cart /} / /Routes /Suspense /BrowserRouter );}### 2. 图片懒加载javascript// 使用原生懒加载img srcimage.jpg loadinglazy alt... /// 使用Intersection Observerconst imageObserver new IntersectionObserver((entries) { entries.forEach(entry { if (entry.isIntersecting) { const img entry.target; img.src img.dataset.src; imageObserver.unobserve(img); } });});document.querySelectorAll(img[data-src]).forEach(img { imageObserver.observe(img);});### 3. 组件懒加载javascript// 弹窗组件懒加载const Modal lazy(() import(./Modal));function App() { const [showModal, setShowModal] useState(false); return ( div button onClick{() setShowModal(true)}打开弹窗/button {showModal ( Suspense fallback{Loading /} Modal onClose{() setShowModal(false)} / /Suspense )} /div );}## 四、代码分割### 1. Webpack配置javascript// webpack.config.jsmodule.exports { optimization: { splitChunks: { chunks: all, cacheGroups: { // 提取公共依赖 vendor: { test: /[\\/]node_modules[\\/]/, name: vendors, priority: 10 }, // 提取公共代码 common: { minChunks: 2, priority: 5, reuseExistingChunk: true } } } }};### 2. 动态导入javascript// 动态导入async function loadFeature() { if (user.isAdmin) { const { AdminPanel } await import(./features/admin/AdminPanel); return AdminPanel /; } const { UserPanel } await import(./features/user/UserPanel); return UserPanel /;}## 五、资源优化### 1. CSS优化css/* 关键CSS内联 */style .critical { color: red; }/style/* 非关键CSS异步加载 */link relpreload hrefstyles.css asstyle onloadthis.onloadnull;this.relstylesheet### 2. JS优化javascript// 减少包体积// 1. 使用Tree Shakingimport { cloneDeep } from lodash; // 整个lodashimport cloneDeep from lodash/cloneDeep; // 只导入使用的函数// 2. 按需加载import { Button } from antd; // 全部导入import Button from antd/lib/button; // 按需导入### 3. 图片优化javascript// 使用WebP格式img srcimage.webp alt... /// 使用srcset响应式图片img srcsetimage-320w.jpg 320w, image-640w.jpg 640w, image-1024w.jpg 1024w sizes(max-width: 320px) 280px, (max-width: 640px) 580px, 1000px srcimage-640w.jpg alt.../## 六、缓存策略### 1. 浏览器缓存javascript// Service Worker缓存const CACHE_NAME app-v1;self.addEventListener(fetch, event { event.respondWith( caches.match(event.request) .then(response { return response || fetch(event.request).then(fetchResponse { return caches.open(CACHE_NAME).then(cache { cache.put(event.request, fetchResponse.clone()); return fetchResponse; }); }); }) );});### 2. HTTP缓存头javascript// 强缓存response.setHeader(Cache-Control, public, max-age31536000);response.setHeader(Expires, new Date(Date.now() 31536000000));// 协商缓存response.setHeader(ETag, xxx);response.setHeader(Last-Modified, new Date());## 七、总结前端性能优化提升用户体验-SSR首屏渲染更快-懒加载减少首屏加载时间-代码分割按需加载-缓存减少重复请求—个人观点仅供参考

相关文章:

【架构实战】前端性能优化:SSR/懒加载/代码分割

一、前端性能优化概述 前端性能直接影响用户体验&#xff1a;关键指标&#xff1a;- FCP&#xff08;首次内容绘制&#xff09;&#xff1a;<1.8s- LCP&#xff08;最大内容绘制&#xff09;&#xff1a;<2.5s- TTI&#xff08;可交互时间&#xff09;&#xff1a;❤️.…...

2025虚幻引擎逆向解包实战:从AES密钥到模型导出的完整避坑指南

1. 逆向解包前的准备工作 做虚幻引擎逆向解包就像拆解一个精密的保险箱&#xff0c;你得先准备好全套工具。我去年折腾黑神话悟空资源提取时&#xff0c;光工具链配置就花了三天时间。最头疼的是不同游戏版本需要的工具组合完全不同&#xff0c;UE4和UE5的差异比想象中更大。 首…...

5个理由为什么Jasminum是Zotero中文文献管理的终极解决方案

5个理由为什么Jasminum是Zotero中文文献管理的终极解决方案 【免费下载链接】jasminum A Zotero add-on to retrive CNKI meta data. 一个简单的Zotero 插件&#xff0c;用于识别中文元数据 项目地址: https://gitcode.com/gh_mirrors/ja/jasminum 还在为Zotero无法准确…...

OBS多平台直播插件:告别重复劳动,一键同步推流到各大平台

OBS多平台直播插件&#xff1a;告别重复劳动&#xff0c;一键同步推流到各大平台 【免费下载链接】obs-multi-rtmp OBS複数サイト同時配信プラグイン 项目地址: https://gitcode.com/gh_mirrors/ob/obs-multi-rtmp 你是不是经常需要在多个直播平台同时开播&#xff1f;每…...

终极指南:如何用MAA实现明日方舟全自动日常管理

终极指南&#xff1a;如何用MAA实现明日方舟全自动日常管理 【免费下载链接】MaaAssistantArknights 《明日方舟》小助手&#xff0c;全日常一键长草&#xff01;| A one-click tool for the daily tasks of Arknights, supporting all clients. 项目地址: https://gitcode.c…...

基于TR-FRET技术的KRAS G12C/CRBN PROTAC试剂盒在靶向蛋白降解研究中的应用

一、KRAS G12C突变的临床意义与治疗挑战KRAS激活突变在25%至30%的非鳞状细胞非小细胞肺癌中可被检测到&#xff0c;是该类癌症中最常见的基因驱动事件。Ras蛋白家族包括KRAS、HRAS和NRAS三种亚型&#xff0c;其中85%的Ras驱动的癌症由KRAS突变造成。KRAS突变在胰腺癌、结直肠癌…...

避坑指南:STM32F401 HAL库编码器模式测速,你的速度值为什么跳变或不准?

STM32F401 HAL库编码器测速实战&#xff1a;从跳变数据到稳定输出的全流程诊断 实验室里&#xff0c;电机转速显示在屏幕上不断跳动——从200RPM突然跌到80RPM&#xff0c;下一秒又飙升到300RPM。这不是科幻电影特效&#xff0c;而是许多开发者在使用STM32F401 HAL库实现编码器…...

微信聊天记录备份恢复终极指南:如何永久保存你的珍贵回忆

微信聊天记录备份恢复终极指南&#xff1a;如何永久保存你的珍贵回忆 【免费下载链接】WechatBakTool 基于C#的微信PC版聊天记录备份工具&#xff0c;提供图形界面&#xff0c;解密微信数据库并导出聊天记录。 项目地址: https://gitcode.com/gh_mirrors/we/WechatBakTool …...

TMS320F28P550SJ9新手避坑指南:从空工程导入、Sysconfig配置到成功点灯的全流程复盘

TMS320F28P550SJ9开发实战&#xff1a;从零搭建LED控制工程的避坑手册 第一次接触德州仪器C2000系列微控制器时&#xff0c;那种既兴奋又忐忑的心情我至今记忆犹新。作为工业控制领域的明星芯片&#xff0c;TMS320F28P550SJ9以其强大的实时处理能力和丰富的外设接口著称&#x…...

从数据集到部署:我的YOLOv8盲道检测项目全记录(附训练曲线和避坑点)

从数据集到部署&#xff1a;我的YOLOv8盲道检测项目全记录 盲道作为城市无障碍设施的重要组成部分&#xff0c;其畅通与否直接关系到视障人士的出行安全。然而在实际场景中&#xff0c;盲道被占用、破损的情况屡见不鲜。本文将完整记录我如何从零开始构建一个基于YOLOv8的盲道障…...

思科交换机如何恢复出厂设置?

在实际网络运维中,“恢复出厂设置”并不是一个简单的按钮操作,而是一个涉及系统、配置文件、VLAN数据库甚至安全擦除策略的系统性操作。 无论是在处理网络故障、设备下线,还是接手一台来源不明的交换机,掌握标准、可靠的恢复流程,都是每一位网工的基本功。 很多人以为执行…...

Git-RSCLIP遥感图像语义理解教程:从原始像素到自然语言描述

Git-RSCLIP遥感图像语义理解教程&#xff1a;从原始像素到自然语言描述 创作者信息 桦漫AIGC集成开发 微信: henryhan1117 技术支持 定制开发 模型部署 1. 引言&#xff1a;让机器看懂遥感图像 你有没有遇到过这样的情况&#xff1a;面对一张卫星拍摄的遥感图像&#xff0c;…...

飞秋Mac版:3步实现Mac与Windows跨平台局域网通信

飞秋Mac版&#xff1a;3步实现Mac与Windows跨平台局域网通信 【免费下载链接】feiq 基于qt实现的mac版飞秋&#xff0c;遵循飞秋协议(飞鸽扩展协议)&#xff0c;支持多项飞秋特有功能 项目地址: https://gitcode.com/gh_mirrors/fe/feiq 飞秋Mac版是基于Qt框架开发的开源…...

Ollama一键部署:DeepSeek-R1推理模型新手入门指南

Ollama一键部署&#xff1a;DeepSeek-R1推理模型新手入门指南 1. 模型简介 DeepSeek-R1-Distill-Qwen-7B是一款专注于推理任务的大型语言模型&#xff0c;由DeepSeek团队开发并开源。这个模型基于Qwen架构进行蒸馏优化&#xff0c;在数学推理、代码生成和逻辑分析任务上表现出…...

多模态大模型鲁棒性瓶颈突破实战(工业级容错框架V3.2首次公开)

第一章&#xff1a;多模态大模型鲁棒性瓶颈的根源诊断与工业级定义 2026奇点智能技术大会(https://ml-summit.org) 多模态大模型在真实工业场景中暴露的鲁棒性缺陷&#xff0c;并非源于单一模块失效&#xff0c;而是跨模态对齐失配、感知-认知语义断层、以及推理链路中对抗脆弱…...

别再让虚线糊一脸!3分钟搞懂机械制图里的剖视图到底怎么画

机械制图剖视图实战指南&#xff1a;从虚线地狱到清晰表达 刚接触机械制图时&#xff0c;最让人抓狂的莫过于满图纸的虚线——它们像蜘蛛网一样纠缠在一起&#xff0c;让人分不清哪条线对应哪个孔洞。记得我第一次用AutoCAD绘制齿轮箱零件图时&#xff0c;为了表达内部油路和轴…...

数字集成电路版图设计实战(二)——Cadence IC反相器版图DRC规则详解与避坑指南

1. DRC规则基础&#xff1a;从读懂规则文件开始 第一次用Cadence IC画反相器版图时&#xff0c;我对着满屏的DRC报错直接懵了——那些密密麻麻的红色标记就像考试卷上的红叉&#xff0c;但更可怕的是我连错在哪都看不懂。后来才发现&#xff0c;DRC规则文件其实就是芯片制造的…...

Ghidra:从NSA开源利器到实战逆向分析平台

1. Ghidra的前世今生&#xff1a;从NSA机密工具到开源利器 第一次听说Ghidra还是在2019年的RSA安全大会上&#xff0c;当时NSA突然宣布开源这款内部使用了十几年的逆向工程工具&#xff0c;整个安全圈都炸开了锅。我清楚地记得现场有研究员开玩笑说&#xff1a;"这感觉就像…...

加密狗 vs USB:从硬件安全到数据传输的全面对比

1. 加密狗与USB的本质区别&#xff1a;从设计初衷说起 第一次接触加密狗时&#xff0c;我也以为它就是个普通的U盘。直到某次安装专业设计软件时&#xff0c;系统反复提示"未检测到合法授权设备"&#xff0c;才意识到这个拇指大小的设备远比想象中复杂。加密狗&…...

保姆级教程:用Zephyr SDK在Ubuntu上5分钟跑通第一个QEMU仿真程序

5分钟极速体验&#xff1a;Ubuntu下用Zephyr SDK运行首个QEMU仿真程序 第一次接触嵌入式实时操作系统&#xff1f;Zephyr的官方文档看起来像天书&#xff1f;别担心&#xff0c;这篇教程将用最简单的步骤&#xff0c;带你跳过复杂的开发环境配置&#xff0c;直接在Ubuntu上体验…...

别再手动编号了!Word交叉引用搞定毕业论文参考文献,5分钟学会(附格式调整技巧)

告别手动编号&#xff1a;用Word交叉引用打造学术论文的智能参考文献系统 写论文最让人抓狂的莫过于参考文献管理——手动编号不仅耗时费力&#xff0c;更可怕的是当你删除或增加文献时&#xff0c;所有编号都得重新调整。我曾见过一位同学在答辩前夜发现参考文献顺序错乱&…...

实战指南:在CentOS 7.9上构建高可用RKE2集群并集成Rancher 2.9.1管理平台

1. 环境准备与系统优化 在CentOS 7.9上部署高可用RKE2集群前&#xff0c;系统环境的准备就像盖房子前打地基一样重要。我遇到过不少因为基础环境没配好导致后续部署失败的案例&#xff0c;这里把关键步骤拆解成小白也能跟上的操作流程。 先说说硬件配置要求。管理节点建议至少4…...

LRCGET:离线音乐歌词批量下载与管理终极指南

LRCGET&#xff1a;离线音乐歌词批量下载与管理终极指南 【免费下载链接】lrcget Utility for mass-downloading LRC synced lyrics for your offline music library. 项目地址: https://gitcode.com/gh_mirrors/lr/lrcget 你是否曾经拥有一个精心收藏的离线音乐库&…...

泛微ECOLOGY9-基于建模与ESB的角色成员动态同步与缓存即时刷新方案

1. 为什么需要角色成员动态同步与缓存刷新 在企业日常运营中&#xff0c;权限管理是个让人头疼的问题。想象一下这样的场景&#xff1a;某位员工刚被调岗到财务部门&#xff0c;理论上应该立即获得财务系统的访问权限&#xff0c;但实际上可能要等上几个小时甚至一天才能正常使…...

NR - Slot Configuration: Understanding TDD-UL-DL Patterns and Flexible Symbols

1. 5G NR时隙配置基础&#xff1a;TDD模式的核心逻辑 想象一下双向车道上的红绿灯控制系统——这就是5G NR中TDD&#xff08;时分双工&#xff09;模式的基本工作原理。在无线通信系统中&#xff0c;上下行资源分配就像车道的方向切换&#xff0c;需要精确的时间控制。我参与过…...

手把手教你学Simulink——基于Simulink的故障诊断:绕组短路、霍尔失效、IGBT开路

目录 手把手教你学Simulink ——基于Simulink的故障诊断&#xff1a;绕组短路、霍尔失效、IGBT开路 一、引言&#xff1a;为何需要主动式故障诊断&#xff1f; 二、系统架构设计 三、故障建模与诊断方法详解 第一大挑战&#xff1a;绕组短路&#xff08;以PMSM匝间短路为例…...

终极指南:如何使用OpenCore Configurator轻松配置黑苹果引导程序

终极指南&#xff1a;如何使用OpenCore Configurator轻松配置黑苹果引导程序 【免费下载链接】OpenCore-Configurator A configurator for the OpenCore Bootloader 项目地址: https://gitcode.com/gh_mirrors/op/OpenCore-Configurator 还在为复杂的OpenCore配置而头疼…...

终极指南:AppleRa1n三步快速绕过iOS 15-16激活锁

终极指南&#xff1a;AppleRa1n三步快速绕过iOS 15-16激活锁 【免费下载链接】applera1n icloud bypass for ios 15-16 项目地址: https://gitcode.com/gh_mirrors/ap/applera1n 你是否遇到过忘记Apple ID密码而无法使用的iPhone&#xff1f;或者购买的二手设备上残留着…...

别再死记硬背AR模型公式了!用Python实战AR(1)和AR(2)模型,5分钟搞懂平稳性判断

用Python实战AR模型&#xff1a;5分钟掌握平稳性判断与核心概念可视化 刚接触时间序列分析时&#xff0c;那些复杂的AR模型公式总让人望而生畏。但当我第一次用Python代码生成模拟数据并看到自相关图规律摆动时&#xff0c;突然理解了所谓"延迟算子"不过是数据记忆效…...

AutoLisp从入门到放弃(十七):条件与循环的实战应用

1. 条件判断在AutoLisp中的实战应用 记得我第一次用AutoLisp写自动化绘图脚本时&#xff0c;if函数就像个严格的交通警察&#xff0c;控制着程序执行的每个路口。这个看似简单的函数&#xff0c;在实际工程中能玩出各种花样。比如在机械制图时&#xff0c;我们经常需要根据不同…...