SvelteKit 最新中文文档教程(20)—— 最佳实践之性能

前言

Svelte,一个语法简洁、入门容易,面向未来的前端框架。

从 Svelte 诞生之初,就备受开发者的喜爱,根据统计,从 2019 年到 2024 年,连续 6 年一直是开发者最感兴趣的前端框架 No.1

image.png

Svelte 以其独特的编译时优化机制著称,具有轻量级高性能易上手等特性,非常适合构建轻量级 Web 项目

为了帮助大家学习 Svelte,我同时搭建了 Svelte 最新的中文文档站点。

如果需要进阶学习,也可以入手我的小册《Svelte 开发指南》,语法篇、实战篇、原理篇三大篇章带你系统掌握 Svelte!

欢迎围观我的“网页版朋友圈”、加入“冴羽·成长陪伴社群”,踏上“前端大佬成长之路”。

性能

SvelteKit 开箱即用地做了很多工作来使您的应用程序尽可能高效:

  • 代码分割,因此只加载当前页面所需的代码
  • 资源预加载,防止出现"瀑布(waterfalls)"(文件请求其他文件的情况)
  • 文件哈希,使您的资源可以永久缓存
  • 请求合并,将从不同服务端 load 函数获取的数据合并成单个 HTTP 请求
  • 并行加载,不同的通用 load 函数同时获取数据
  • 数据内联,服务端渲染期间使用 fetch 发出的请求可以在浏览器中重放而无需重新发出请求
  • 保守的失效处理,因此 load 函数仅在必要时重新运行
  • 预渲染(如有必要,可按路由配置),使没有动态数据的页面可以立即提供服务
  • 链接预加载,以便提前主动获取客户端导航所需的数据和代码

尽管如此,我们(尚)不能消除所有导致性能下降的因素。要获得最大性能,您应该注意以下建议。

诊断问题

Google 的 PageSpeed Insights 和(用于更高级分析的)WebPageTest 是了解已部署到互联网的网站性能特征的出色工具。

您的浏览器还包含有用的开发者工具,用于分析您的网站,无论是已部署还是在本地运行:

  • Chrome - Lighthouse、Network 和 Performance 开发工具
  • Edge - Lighthouse、Network 和 Performance 开发工具
  • Firefox - Network 和 Performance 开发工具
  • Safari - 提升网页性能

请注意,在 dev 模式下本地运行的网站会表现出与生产应用程序不同的行为,因此您应该在构建后在预览模式下进行性能测试。

检测

如果您在浏览器的网络标签中看到 API 调用耗时过长,想了解原因,您可以考虑使用 OpenTelemetry 或 Server-Timing 头 等工具来检测您的后端。

优化资源

图片

减小图片文件的大小通常是对网站性能影响最大的改变之一。Svelte 提供了 @sveltejs/enhanced-img 包,详见图片页面,可以让这个过程更容易。此外,Lighthouse 对识别性能影响最大的图片很有帮助。

视频

视频文件可能非常大,因此应特别注意确保它们经过优化:

  • 使用 Handbrake 等工具压缩视频。考虑将视频转换为 .webm.mp4 等 web 友好的格式。
  • 您可以使用 preload="none" 对折叠区域以下的视频进行延迟加载(但请注意,这会在用户开始播放时减慢播放速度)。
  • 使用 FFmpeg 等工具从静音视频中删除音轨。

字体

当用户访问页面时,SvelteKit 会自动预加载关键的 .js.css 文件,但默认情况下不会预加载字体,因为这可能会导致下载不必要的文件(例如 CSS 中引用但实际上在当前页面上未使用的字体粗细)。话虽如此,正确预加载字体可以对网站的速度感知产生很大影响。在您的 handle hook 中,您可以使用包含字体的 preload 过滤器调用 resolve

通过子集化字体,您可以减小字体文件的大小。

减少代码大小

Svelte 版本

我们推荐使用最新版本的 Svelte。Svelte 5 比 Svelte 4 更小更快,而 Svelte 4 又比 Svelte 3 更小更快。

rollup-plugin-visualizer 可以帮助识别哪些包对网站大小贡献最大。您还可以通过手动检查构建输出发现删除代码的机会(在您的 Vite 配置中使用 build: { minify: false } 使输出可读,但记得在部署应用程序之前撤销此更改),或通过浏览器开发工具的网络标签。

外部脚本

尽量减少在浏览器中运行的第三方脚本数量。例如,与其使用基于 JavaScript 的分析工具,不如考虑使用服务端实现,比如许多带有 SvelteKit 适配器的平台,包括 Cloudflare、Netlify 和 Vercel 所提供的解决方案。

要在 Web Worker 中运行第三方脚本(避免阻塞主线程),请使用 Partytown 的 SvelteKit 集成。

选择性加载

使用静态 import 声明导入的代码将自动与页面的其余部分打包在一起。如果某段代码仅在满足特定条件时才需要,请使用动态 import(...) 形式来选择性地延迟加载组件。

导航

预加载

您可以使用链接选项预先加载必要的代码和数据来加快客户端导航。当您创建新的 SvelteKit 应用程序时,<body> 元素上是默认有配置的。

非必要数据

对于加载缓慢且不需要立即使用的数据,从 load 函数返回的对象可以包含 promise 而不是数据本身。对于服务端 load 函数,这将导致数据在导航(或初始页面加载)后流式传输。

防止瀑布问题

最大的性能杀手之一是所谓的瀑布问题,即一系列按顺序发出的请求。这可能发生在服务端或浏览器中。

  • 当您的 HTML 请求 JS,然后请求 CSS,然后请求背景图片和网络字体时,可能会在浏览器中出现资源瀑布。SvelteKit 通过添加 modulepreload 标签或头部,将为您解决这类问题,但您应该查看开发工具中的网络标签以检查是否需要预加载其他资源。如果您使用网络字体,请特别注意这一点,因为它们需要手动处理。
  • 如果通用 load 函数发起 API 调用来获取当前用户,然后使用该响应中的详细信息来获取已保存项目的列表,然后使用该响应来获取每个项目的详细信息,浏览器最终将发出多个顺序请求。这对性能来说是致命的,尤其是对于物理位置远离您后端的用户。在可能的情况下使用服务端 load 函数来避免这个问题。
  • 服务端 load 函数也不能免疫瀑布问题(尽管它们的代价要小得多,因为它们很少涉及高延迟的往返)。例如,如果您查询数据库以获取当前用户,然后使用该数据进行第二次查询以获取已保存项目的列表,使用带有数据库连接的单个查询通常会更高效。

托管

为了最小化延迟,你的前端应该与后端位于同一数据中心。对于没有中央后端的站点,许多 SvelteKit 适配器支持部署到 edge,这意味着从离用户最近的服务器处理每个用户的请求。这可以显著减少加载时间。一些适配器甚至支持按路由配置部署。您还应该考虑从 CDN(通常是 edge 网络)提供图片服务 — 许多 SvelteKit 适配器的主机会自动完成这项工作。

确保您的主机使用 HTTP/2 或更新版本。Vite 的代码分割创建了许多小文件以提高缓存能力,这会带来出色的性能表现,但这建立在您的文件可以通过 HTTP/2 并行加载的前提下。

延伸阅读

在大多数情况下,构建高性能的 SvelteKit 应用程序与构建任何高性能的 Web 应用程序是一样的。您应该能够将这些来自通用性能资源(如 Core Web Vitals)的信息应用到任何您构建的 Web 体验中。

Svelte 中文文档

点击查看中文文档:SvelteKit 性能

系统学习 Svelte,欢迎入手小册《Svelte 开发指南》。语法篇、实战篇、原理篇三大篇章带你系统掌握 Svelte!

此外我还写过 JavaScript 系列、TypeScript 系列、React 系列、Next.js 系列、冴羽答读者问等 14 个系列文章, 全系列文章目录:https://github.com/mqyqingfeng/Blog

欢迎围观我的“网页版朋友圈”、加入“冴羽·成长陪伴社群”,踏上“前端大佬成长之路”。

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

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

相关文章

【LangChain核心组件】Memory:让大语言模型拥有持续对话记忆的工程实践

目录 一、Memory架构设计解析 1. 核心组件关系图 2. 代码中的关键实现 二、对话记忆的工程实现 1. 消息结构化存储 2. 动态提示组装机制 三、Memory类型选型指南 四、生产环境优化实践 1. 记忆容量控制 2. 记忆分片策略 3. 记忆检索增强 五、典型问题调试技巧 1. …

适应 AI 时代的软件开发流程:用 AI + TDD 构建可维护项目

🧠 适应 AI 时代的软件开发流程:用 AI + TDD 构建可维护项目 本文面向有系统开发经验的工程师,分享如何结合 Git 管理、AI 协作、YAML 驱动与 TDD 开发方式,高效构建一个可维护、可协作、可交付的嵌入式或通用工程项目。适合 BLE 模块、协议栈组件、物联网控制系统等项目落…

使用 chromedriver 实现网络爬虫【手抄】

1、引用 selenium 包 <dependency><groupId>org.seleniumhq.selenium</groupId><artifactId>selenium-java</artifactId><version>4.29.0</version> </dependency> <dependency><groupId>org.seleniumhq.seleniu…

Python项目--基于Python的自然语言处理文本摘要系统

1. 项目概述 自然语言处理(NLP)是人工智能领域中一个重要的研究方向&#xff0c;而文本摘要作为NLP的一个重要应用&#xff0c;在信息爆炸的时代具有重要意义。本项目旨在开发一个基于Python的文本摘要系统&#xff0c;能够自动从长文本中提取关键信息&#xff0c;生成简洁而全…

【Vue #3】指令补充样式绑定

一、指令修饰符 Vue 的指令修饰符&#xff08;Directive Modifiers&#xff09;是 Vue 模板语法中的重要特性&#xff0c;它们以半角句号 . 开头&#xff0c;用于对指令的绑定行为进行特殊处理 修饰符作用如下&#xff1a; 简化事件处理&#xff08;如阻止默认行为、停止冒泡…

Reinforcement Learning强化学习--李宏毅机器学习笔记

个人学习笔记&#xff0c;如有错误欢迎指正&#xff0c;也欢迎交流&#xff0c;其他笔记见个人空间 强化学习 vs 监督学习 监督学习&#xff08;Supervised Learning&#xff09;&#xff1a;你有输入和明确的输出标签&#xff0c;例如图像分类。 强化学习&#xff08;Rein…

Windows VsCode Terminal窗口使用Linux命令

背景描述&#xff1a; 平时开发环境以Linux系统为主&#xff0c;有时又需要使用Windows系统下开发环境&#xff0c;为了能像Linux系统那样用Windows VsCode&#xff0c;Terminal命令行是必不可少内容。 注&#xff1a;Windows11 VsCode 1.99.2 下面介绍&#xff0c;如何在V…

软件测试之测试数据生成(Excel版)

这是Excel生成测试数据的函数使用 1.时间 1.1.时间 例生成2022-05-01之前一年内任意时间点: =TEXT("2022-05-01"-RAND()-RANDBETWEEN(1,365),"yyyy-mm-dd hh:mm:ss")1.2.年月日 yyyy-mm-dd 以当前时间生成10年的日期 =TEXT(NOW()-RAND()-RANDBETWE…

libwebsocket建立服务器需要编写LWS_CALLBACK_ADD_HEADERS事件处理

最近在使用libwebsocket&#xff0c;感觉它搭建Http与websocket服务器比较简单&#xff0c;不像poco库那么庞大&#xff0c;但当我使用它建立websocket服务器后&#xff0c;发现websocket客户端连接一直没有连接成功&#xff0c;不知道什么原因&#xff0c;经过一天的调试&…

从 PyTorch 到 ONNX:深度学习模型导出全解析

在模型训练完毕后&#xff0c;我们通常希望将其部署到推理平台中&#xff0c;比如 TensorRT、ONNX Runtime 或移动端框架。而 ONNX&#xff08;Open Neural Network Exchange&#xff09;正是 PyTorch 与这些平台之间的桥梁。 本文将以一个图像去噪模型 SimpleDenoiser 为例&a…

Hadoop集群部署教程-P6

Hadoop集群部署教程-P6 Hadoop集群部署教程&#xff08;续&#xff09; 第二十一章&#xff1a;监控与告警系统集成 21.1 Prometheus监控体系搭建 Exporter部署&#xff1a; # 部署HDFS Exporter wget https://github.com/prometheus/hdfs_exporter/releases/download/v1.1.…

【Altium】AD-生成PDF文件图纸包含太多的空白怎么解决

1、 文档目标 AD设计文件导出PDF时&#xff0c;图纸模板方向设置问题 2、 问题场景 AD使用Smart PDF导出PDF时&#xff0c;不管你怎么设置页面尺寸&#xff0c;只要从横向转为纵向输出&#xff0c;输出的始终是横向纸张&#xff08;中间保留纵向图纸&#xff0c;两边大量留白…

大厂面试:六大排序

前言 本篇博客集中了冒泡&#xff0c;选择&#xff0c;二分插入&#xff0c;快排&#xff0c;归并&#xff0c;堆排&#xff0c;六大排序算法 如果觉得对你有帮助&#xff0c;可以点点关注&#xff0c;点点赞&#xff0c;谢谢你&#xff01; 1.冒泡排序 //冒泡排序&#xff…

大模型开发:源码分析 Qwen 2.5-VL 视频抽帧模块(附加FFmpeg 性能对比测试)

目录 qwen 视频理解能力 messages 构建 demo qwen 抽帧代码分析 验证两个实际 case 官网介绍图 性能对比&#xff1a;ffmpeg 抽帧、decord 库抽帧 介绍 联系 对比 测试结果 测试明细 ffmpeg 100 qps 测试&#xff08;CPU&#xff09; decord 100 qps 测试&#x…

git的上传流程

好久没使用git 命令上传远程仓库了。。。。。温习了一遍&#xff1b; 几个注意点--单个文件大小不能超过100M~~~ 一步步运行下面的命令&#xff1a; 进入要上传的文件夹内&#xff0c;点击git bash 最终 hbu的小伙伴~有需要nndl实验的可以自形下载哦

驱动学习专栏--字符设备驱动篇--2_字符设备注册与注销

对于字符设备驱动而言&#xff0c;当驱动模块加载成功以后需要注册字符设备&#xff0c;同样&#xff0c;卸载驱动模 块的时候也需要注销掉字符设备。字符设备的注册和注销函数原型如下所示 : static inline int register_chrdev(unsigned int major, const char *name, const…

redis 放置序列化的对象,如果修改对象,需要修改版本号吗?

在 Redis 中存储序列化对象时,如果修改了对象的类结构(例如增删字段、修改字段类型或顺序),是否需要修改版本号取决于序列化协议的兼容性策略和业务场景的容错需求。以下是详细分析: 1. 为什么需要考虑版本号? 序列化兼容性问题: 当对象的类结构发生变化时,旧版本的序列…

WPF ObjectDataProvider

在 WPF(Windows Presentation Foundation)中,ObjectDataProvider 是一个非常有用的类,用于将非 UI 数据对象(如业务逻辑类或服务类)与 XAML 绑定集成。它允许在 XAML 中直接调用方法、访问属性或实例化对象,而无需编写额外的代码。以下是关于 ObjectDataProvider 的详细…

深度学习-损失函数 python opencv源码(史上最全)

目录 定义 种类 如何选择损失函数&#xff1f; 平方&#xff08;均方&#xff09;损失函数&#xff08;Mean Squared Error, MSE&#xff09; 均方根误差 交叉熵 对数损失 笔记回馈 逻辑回归中一些注意事项&#xff1a; 定义 损失函数又叫误差函数、成本函数、代价函数…

poll为什么使用poll_list链表结构而不是数组 - 深入内核源码分析

一&#xff1a;引言 在Linux内核中,poll机制是一个非常重要的I/O多路复用机制。它允许进程监视多个文件描述符,等待其中任何一个进入就绪状态。poll的内部实现使用了poll_list链表结构而不是数组,这个设计选择背后有其深层的技术考量。本文将从内核源码层面深入分析这个设计决…