1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
|
---
title: Web 性能
slug: Web/Performance
tags:
- API
- HTML
- JavaScript
- Web
- 性能
- 性能优化
translation_of: Web/Performance
---
<p>Web 性能是客观的衡量标准,是用户对加载时间和运行时的直观体验。Web 性能指页面加载到可交互和可响应所消耗的时间,以及页面在交互时的流畅度——滚动是否顺滑?按钮能否点击?弹窗能否快速打开,动画是否平滑?Web 性能既包括客观的度量如加载时间,每秒帧数和到页面可交互的时间;也包括用户的对页面内容加载时间的主观感觉。 </p>
<p>页面响应时间越长,越多的用户就会放弃该网站。重要的是,通过使体验尽可能早地变得可用和交互,同时异步地加载长尾体验部分,来最大程度地减少加载和响应时间,并添加其他功能以降低延迟。</p>
<p>有很多工具,API 和最佳实践帮助我们测量和改进网页性能。本章对此有所讲解。</p>
<h2 id="关键性能指南">关键性能指南</h2>
<p>{{LandingPageListSubpages}}</p>
<div class="cleared topicpage-table">
<div class="section">
<h2 id="初学者教程">初学者教程</h2>
<p>MDN <a href="/zh-CN/docs/Learn/Performance">Web 性能学习专区</a> 有着涵盖性能要素的最新教程。 如果您是性能新手,请从这里开始:</p>
<dl>
<dt><a href="/zh-CN/docs/Learn/Performance/web_performance_overview">Web 性能:概述</a></dt>
<dd>Web性能学习路径概述。 在这里开始您的旅程。</dd>
<dt><a href="/zh-CN/docs/Learn/Performance/What_is_web_performance">什么是 Web 性能?</a></dt>
<dd>该文从一个模块开始,很好地讲述了性能到底是什么——包括我们在考虑性能时需要考虑的工具、指标、API、网络和人群,以及如何使性能成为 Web 开发工作流程的一部分。</dd>
<dt><a href="/zh-CN/docs/Learn/Performance/perceived_performance">用户如何看待性能?</a></dt>
<dd>比网站在毫秒内响应速度更重要的是,用户对网站的感知速度有多快。这些感知受到页面实际加载时间、空闲、用户交互响应以及滚动和其他动画的平滑度的影响。在本文中,我们将随着最佳练习来提升用户感知(而不是实际时间)并讨论各种加载指标、动画和响应性指标。</dd>
<dt><a href="/zh-CN/docs/Learn/Performance/web_performance_basics">Web 性能基础</a></dt>
<dd>除了HTML,CSS,JavaScript和媒体文件这些前端模块之外,还有其他影响Web性能的因素,它们可能会导致应用程序变慢,或在主观和客观上使应用程序变快。有许多与Web性能相关的API、开发人员工具、最佳实践和不当做法。我们将在基础层面上介绍这些影响因素,并提供进阶优化其中每一项性能的链接。</dd>
<dt><a href="/zh-CN/docs/Learn/Performance/HTML">HTML 性能特性</a></dt>
<dd>标签的某些属性和顺序可能会影响网站性能。 通过最大程度地减少DOM节点的数量,确保使用最佳顺序和属性,包括样式、脚本、媒体和第三方脚本等内容,可以大大改善用户体验。 该文详细介绍了如何使用 HTML 来确保最佳性能。</dd>
<dt><a href="/zh-CN/docs/Learn/Performance/Multimedia">多媒体:图像与视频</a></dt>
<dd>Web 性能的最小代价通常是媒体优化。基于每个用户代理的能力、大小和像素密度来服务不同的媒体文件已成为可能。另外,如从背景图像中删除音频轨迹,可进一步提升性能。该文讨论视频、音频和图像内容对性能的影响,以及确保影响尽可能小的方法。</dd>
<dt><a href="/zh-CN/docs/Learn/Performance/CSS_performance">CSS 性能特性</a></dt>
<dd>CSS 对于提高性能来说可能是一个不太重要的优化点,但是某些 CSS 特性对性能的影响比其他特性更大。在该文中,我们将研究一些影响性能的 CSS 属性,并提供样式处理的建议方法,以确保性能不受负面影响。</dd>
<dt><a href="/zh-CN/docs/Learn/Performance/JavaScript">JavaScript 性能最佳实践</a></dt>
<dd>如果正确使用JavaScript,则可以提供交互式和身临其境的 Web 体验——否则可能会严重损害下载时间、渲染时间、应用内性能、电池寿命和用户体验。 该文概述了一些值得思考的 JavaScript 最佳实践,以确保即使复杂的内容也尽可能地具有高性能。</dd>
<dt><a href="/zh-CN/docs/Learn/Performance/Mobile">移动端性能</a></dt>
<dd>随着移动设备上的Web访问普及,并且所有移动平台都具有功能完善的Web浏览器,但由于受限于带宽、CPU、电池续航等因素,因此考虑这些平台上Web内容的性能非常重要。 本文着眼于特定于移动设备的性能注意事项。</dd>
</dl>
</div>
<div class="section">
<h2 class="Using_Performance_APIs" id="Using_Performance_APIs" name="Using_Performance_APIs">使用 Performance API</h2>
<dl>
<dt><a href="/zh-CN/docs/Web/API/Performance_API/Using_the_Performance_API">Performance API</a></dt>
<dd>该指南介绍了如何使用 <a class="external external-icon" href="https://w3c.github.io/hr-time/" rel="noopener">High-Resolution Time</a> 标准中定义的 <code><a href="/zh-CN/docs/Web/API/Performance" title="The Performance interface provides access to performance-related information for the current page. It's part of the High Resolution Time API, but is enhanced by the Performance Timeline API, the Navigation Timing API, the User Timing API, and the Resource Timing API.">Performance</a></code> 接口。</dd>
<dt><a href="/zh-CN/docs/Web/API/Resource_Timing_API/Using_the_Resource_Timing_API">Resource Timing API</a></dt>
<dd><a href="/zh-CN/docs/Web/API/Resource_Timing_API">资源加载和定时加载</a> 这些资源,包括管理资源缓冲区和处理CORS</dd>
<dt><a href="/zh-CN/docs/Web/API/Performance_Timeline/Using_Performance_Timeline">性能时间线</a></dt>
<dd><a href="/zh-CN/docs/Web/API/Performance_Timeline">Performance Timeline</a> 标准定义了对 <a href="/zh-CN/docs/Web/API/Performance" title="The Performance interface provides access to performance-related information for the current page. It's part of the High Resolution Time API, but is enhanced by the Performance Timeline API, the Navigation Timing API, the User Timing API, and the Resource Timing API."><code>Performance</code></a> 接口的扩展,以支持应用程序中的客户端延迟测量。这些接口一起可以用来帮助识别应用程序的性能瓶颈。</dd>
<dt><a href="/zh-CN/docs/Web/API/User_Timing_API/Using_the_User_Timing_API">User Timing API</a> </dt>
<dd>使用创建特定于应用程序的时间戳 <a href="/zh-CN/docs/Web/API/User_Timing_API">user timing API</a>'s “标记”和“度量”条目类型-它们是浏览器性能时间轴的一部分。</dd>
<dt><a href="/zh-CN/docs/Web/API/Frame_Timing_API/Using_the_Frame_Timing_API">Frame Timing API</a></dt>
<dd><code><a href="/zh-CN/docs/Web/API/PerformanceFrameTiming">PerformanceFrameTiming</a></code> 接口提供有关浏览器事件循环的<em>帧</em>计时数据。</dd>
<dt><a href="/zh-CN/docs/Web/API/Beacon_API/Using_the_Beacon_API">Beacon API</a></dt>
<dd><small>使用 <a href="/zh-CN/docs/Web/API/Beacon_API">Beacon</a> 接口调度发送给服务器的异步非阻塞请求。</small></dd>
<dt><a href="/zh-CN/docs/Web/API/Intersection_Observer_API/Timing_element_visibility">Intersection Observer API</a></dt>
<dd>通过 <a href="/zh-CN/docs/Web/API/Intersection_Observer_API">Intersection Observer API</a> 学习对元素可见性的监测,并在关注的元素变得可见时被异步通知。</dd>
</dl>
<h2 class="Other_documentation" id="Other_documentation" name="Other_documentation">其他文档</h2>
<dl>
<dt><a href="/zh-CN/docs/Tools/Performance">开发者工具中与性能相关的功能</a></dt>
<dd>本节提供有关如何使用和理解开发人员工具中的性能特性的信息,包括 <a href="/zh-CN/docs/Tools/Performance/Waterfall">Waterfall</a>, <a href="/zh-CN/docs/Tools/Performance/Call_Tree">Call Tree</a>, 和 <a href="/zh-CN/docs/Tools/Performance/Flame_Chart">Flame Charts</a>.</dd>
<dt></dt>
<dt><a href="/zh-CN/docs/Performance/Profiling_with_the_Built-in_Profiler">使用内置分析器进行分析</a></dt>
<dd>了解如何使用Firefox的内置分析器来分析应用程序性能。</dd>
</dl>
</div>
</div>
<h2 id="各种术语">各种术语</h2>
<div class="index">
<ul class="index">
<li>{{glossary('Beacon')}}</li>
<li>{{glossary('Brotli compression')}}</li>
<li>{{glossary('Client hints')}}</li>
<li>{{glossary('Code splitting')}}</li>
<li>{{glossary('CSSOM')}}</li>
<li>{{glossary('Domain sharding')}}</li>
<li>{{glossary('Effective connection type')}}</li>
<li>{{glossary('First contentful paint')}}</li>
<li>{{glossary('First CPU idle')}}</li>
<li>{{glossary('First input delay')}}</li>
<li>{{glossary('First interactive')}}</li>
<li>{{glossary('First meaningful paint')}}</li>
<li>{{glossary('First paint')}}</li>
<li>{{glossary('HTTP')}}</li>
<li>{{glossary('HTTP_2', 'HTTP/2')}}</li>
<li>{{glossary('Jank')}}</li>
<li>{{glossary('Latency')}}</li>
<li>{{glossary('Lazy load')}}</li>
<li>{{glossary('Long task')}}</li>
<li>{{glossary('Lossless compression')}}</li>
<li>{{glossary('Lossy compression')}}</li>
<li>{{glossary('Main thread')}}</li>
<li>{{glossary('Minification')}}</li>
<li>{{glossary('Network throttling')}}</li>
<li>{{glossary('Packet')}}</li>
<li>{{glossary('Page load time')}}</li>
<li>{{glossary('Page prediction')}}</li>
<li>{{glossary('Parse')}}</li>
<li>{{glossary('Perceived performance')}}</li>
<li>{{glossary('Prefetch')}}</li>
<li>{{glossary('Prerender')}}</li>
<li>{{glossary('QUIC')}}</li>
<li>{{glossary('RAIL')}}</li>
<li>{{glossary('Real User Monitoring')}}</li>
<li>{{glossary('Resource Timing')}}</li>
<li>{{glossary('Round Trip Time (RTT)')}}</li>
<li>{{glossary('Server Timing')}}</li>
<li>{{glossary('Speculative parsing')}}</li>
<li>{{glossary('Speed index')}}</li>
<li>{{glossary('SSL')}}</li>
<li>{{glossary('Synthetic monitoring')}}</li>
<li>{{glossary('TCP handshake')}}</li>
<li>{{glossary('TCP slow start')}}</li>
<li>{{glossary('Time to first byte')}}</li>
<li>{{glossary('Time to interactive')}}</li>
<li>{{glossary('TLS')}}</li>
<li>{{glossary('TCP', 'Transmission Control Protocol (TCP)')}}</li>
<li>{{glossary('Tree shaking')}}</li>
<li>{{glossary('Web performance', 'Web 性能')}}</li>
</ul>
</div>
<h2 id="即将编写的文档">即将编写的文档</h2>
<dl>
<dt><a href="/zh-CN/docs/Learn/Performance/JavaScript">JavaScript 性能最佳实践</a></dt>
<dd>JavaScript,如果使用得当,可以提供交互式和身临其境的web体验...或者它会严重影响下载时间、渲染时间、应用内性能、电池寿命和用户体验。本文概述了一些JavaScript最佳实践,这些实践可以确保即使是复杂内容的性能也是最高的。</dd>
<dt><a href="/zh-CN/docs/Learn/Performance/Mobile">移动端性能</a></dt>
<dd>由于移动设备上的web访问非常流行,而且所有移动平台都有成熟的web浏览器,但带宽、CPU和电池寿命可能有限,因此考虑这些平台上web内容的性能非常重要。本文还讨论了移动设备特定的性能考虑因素。</dd>
<dt>Web 字体性能</dt>
<dd>性能方面一个经常被忽视的方面是web字体。Web字体在Web设计中比以往任何时候都更加突出,然而许多开发人员只是简单地将它们从第三方服务中嵌入而不考虑它。在本文中,我们将介绍如何使用高效的文件格式和子设置使字体文件尽可能小。从那以后,我们将继续讨论浏览器如何文本,以及如何使用 CSS 和 JavaScript 功能,以确保您的字体快速呈现,并将对用户体验的干扰降到最低。</dd>
<dt>性能瓶颈</dt>
<dd></dd>
<dt>理解带宽</dt>
<dd>
<div>
<div class="public-DraftStyleDefault-block public-DraftStyleDefault-ltr"><span><span>带宽是以兆位(Mb)或千位(Kb)为单位的每秒可发送的数据量。本文将解释带宽在富媒体internet应用程序中的作用,如何测量带宽,以及如何优化应用程序以最大限度地利用可用带宽。</span></span></div>
</div>
</dd>
<dt>TLS 在性能中的作用</dt>
<dd>
<p>TLS或HTTPS(我们通常称之为TLS)对于创建安全和安全的用户体验至关重要。虽然硬件降低了TLS对服务器性能的负面影响,但它仍然代表了我们等待浏览器连接到服务器所花费的大量时间。本文解释了TLS握手过程,并提供了一些减少时间的技巧,例如OCSP装订、HSTS预加载头,以及资源提示在为第三方屏蔽TLS延迟方面的潜在作用。</p>
</dd>
<dt>阅读性能图表</dt>
<dd>开发人员工具提供有关性能、内存和网络请求的信息。知道如何阅读 <a href="/zh-CN/docs/Tools/Performance/Waterfall">waterfall</a> charts, <a href="/zh-CN/docs/Tools/Performance/Call_Tree">call trees</a>, traces, <a href="/zh-CN/docs/Tools/Performance/Flame_Chart">flame charts</a> ,和 <a href="/zh-CN/docs/Tools/Performance/Allocations">allocations</a> 在浏览器中,开发人员工具将帮助您理解其他性能工具中的瀑布图和火焰图。</dd>
<dt>其他媒体格式</dt>
<dd>当涉及到图像和视频时,有比你可能意识到的更多的格式。其中一些格式可以通过进一步减小文件大小来进一步优化富媒体页面。在本指南中,我们将讨论一些替代的媒体格式,如何负责任地使用它们,使不受支持的浏览器不被冷落,以及一些关于将现有资源转换为它们的高级指导。</dd>
<dt>分析 JavaScript bundle</dt>
<dd>毫无疑问,JavaScript是现代web开发的重要组成部分。虽然您应该一直努力减少在应用程序中使用的JavaScript数量,但是很难知道从哪里开始。在本指南中,我们将向您展示如何分析应用程序的脚本捆绑包,以便您知道您在使用什么,以及如何检测应用程序在捆绑包之间是否包含重复的脚本。</dd>
<dt><a href="/zh-CN/docs/Web/Performance/Lazy_loading">延迟加载</a></dt>
<dd>在初始页面加载时并不总是需要加载所有web应用程序资产。延迟加载是将页面上的资产(如脚本、图像等)的加载推迟到稍后的时间点,即实际需要这些资产的时候。</dd>
<dt>使用动态 import 延迟加载 JavaScript</dt>
<dd>当开发人员听到术语“延迟加载”时,他们会立即想到当滚动到视口时加载的折叠图像下方。但是你知道你也可以延迟加载JavaScript吗?在本指南中,我们将讨论dynamic import()语句,这是现代浏览器中按需加载JavaScript模块的功能。当然,由于这个特性不是到处都可用的,我们还将向您展示如何配置您的工具以广泛兼容的方式使用此特性。</dd>
<dt><a href="/zh-CN/docs/Web/Performance/Controlling_resource_delivery_with_resource_hints">使用资源提示(resource hints)控制资源传输</a></dt>
<dd>浏览器通常比我们更了解资源的优先级和交付,但是他们离克莱里奥万特还很远。本机浏览器特性使我们能够在浏览器应该连接到另一个服务器时提示浏览器,或者在浏览器知道它需要资源之前预先加载资源。如果使用得当,这可以使快速体验看起来更快。在本文中,我们将介绍诸如rel=preconnect、rel=dns prefetch、rel=prefetch和rel=preload等本机浏览器功能,以及如何使用它们来发挥您的优势。</dd>
<dt><a href="/zh-CN/docs/Web/Performance/Performance_budgets">性能预算</a></dt>
<dd>营销、设计和销售需求,以及开发人员的经验,通常是广告膨胀、第三方脚本和其他会降低web性能的功能。为了帮助设置优先级,设置一个性能预算是很有帮助的:一组在开发阶段不能超过的限制。在本文中,我们将讨论创建和坚持绩效预算。</dd>
<dt><a href="/zh-CN/docs/Web/Performance/Checklist">Web 性能检查清单</a></dt>
<dd>一个在开发应用程序时要考虑性能清单,其中包含如何实现每个特性的教程链接,包括 Service Worker、性能问题诊断、字体加载最佳实践、客户端提示、创建高效的动画等。</dd>
<dt><a href="/zh-CN/docs/Web/Performance/Mobile_performance_checklist">Mobile </a><a href="/zh-CN/docs/Web/Performance/Checklist">性能检查清单</a></dt>
<dd>A concise checklist of performance considerations impacting mobile network users on hand-held, battery operated devices.</dd>
</dl>
<h2 id="也可以看看">也可以看看</h2>
<p>HTML</p>
<ul>
<li><a href="/zh-CN/docs/Web/HTML/Element/picture"><code><picture></code> 元素</a></li>
<li><a href="/zh-CN/docs/Web/HTML/Element/video"><code><video></code> 元素</a></li>
<li><a href="/zh-CN/docs/Web/HTML/Element/source">The <code><source></code> Element</a></li>
<li><a href="/zh-CN/docs/Web/HTML/Element/img#Attributes">The <code><img> srcset</code> attribute</a>
<ul>
<li>响应式图片</li>
</ul>
</li>
<li><a href="/zh-CN/docs/Web/HTML/Preloading_content">使用 <code>rel="preload"</code> 预加载内容 —— </a><a href="https://w3c.github.io/preload/">(https://w3c.github.io/preload/ </a>)</li>
</ul>
<p>CSS</p>
<ul>
<li><a href="/zh-CN/docs/Web/CSS/will-change">will-change</a></li>
<li>GPU v CPU</li>
<li>测量布局</li>
<li>字体加载最佳实践</li>
</ul>
<p>JavaScript</p>
<ul>
<li><a href="/zh-CN/docs/Web/Events/DOMContentLoaded">DOMContentLoaded</a></li>
<li><a href="/zh-CN/docs/Glossary/Garbage_collection">垃圾回收机制(GC)</a></li>
<li><a href="/zh-CN/docs/Web/API/window/requestAnimationFrame">requestAnimationFrame</a></li>
</ul>
<p>APIs</p>
<ul>
<li><a href="/zh-CN/docs/Web/API/Performance_API">Performance API</a></li>
<li><a href="/zh-CN/docs/Web/API/Navigation_timing_API">Navigation Timing API</a></li>
<li><a href="/zh-CN/docs/Web/API/Media_Capabilities_API/Using_the_Media_Capabilities_API">Media Capabilities API</a></li>
<li><a href="/zh-CN/docs/Web/API/Network_Information_API">Network Information API</a></li>
<li><a href="/zh-CN/docs/Web/API/PerformanceNavigationTiming">PerformanceNavigationTiming</a></li>
<li><a href="/zh-CN/docs/Web/API/Battery_Status_API">Battery Status API</a></li>
<li><a href="/zh-CN/docs/Web/API/Navigator/deviceMemory">Navigator.deviceMemory</a></li>
<li><a href="/zh-CN/docs/Web/API/Intersection_Observer_API">Intersection Observer</a></li>
<li><a href="/zh-CN/docs/Web/API/User_Timing_API/Using_the_User_Timing_API">Using the User Timing AP</a>I</li>
<li><a href="/zh-CN/docs/Web/API/Long_Tasks_API">Long Tasks API</a></li>
<li><a href="/zh-CN/docs/Web/API/DOMHighResTimeStamp">High Resolution Timing API</a> (<a href="https://w3c.github.io/hr-time/">https://w3c.github.io/hr-time/)</a></li>
<li><a href="/zh-CN/docs/Web/API/Resource_Timing_API/Using_the_Resource_Timing_API">Resource Timing API</a></li>
<li><a href="/zh-CN/docs/Web/API/Page_Visibility_API">页面可见性</a></li>
<li><a href="/zh-CN/docs/Web/API/Background_Tasks_API">Cooperative Scheduling of Background Tasks API</a>
<ul>
<li style="margin-top: 0.25em;"><a href="/zh-CN/docs/Web/API/Window/requestIdleCallback">requestIdleCallback() </a></li>
</ul>
</li>
<li><a href="/zh-CN/docs/Web/API/Beacon_API/Using_the_Beacon_API">Beacon API</a></li>
<li>资源提示 - <a href="/zh-CN/docs/Web/HTTP/Headers/X-DNS-Prefetch-Control">dns-prefetch</a>, preconnect, <a href="/zh-CN/docs/Web/HTTP/Link_prefetching_FAQ">prefetch</a>, and prerender</li>
<li><a href="/zh-CN/docs/Web/API/FetchEvent/navigationPreload">Fetchevent.navigationPreload</a></li>
<li><a href="/zh-CN/docs/Web/API/PerformanceServerTiming">Performance Server Timing API</a></li>
</ul>
<p>Headers</p>
<ul>
<li><a href="/zh-CN/docs/Web/HTTP/Headers/Content-Encoding">Content-encoding</a></li>
<li>HTTP/2</li>
<li><a href="/zh-CN/docs/Glossary/GZip_compression">gZip</a></li>
<li>Client Hints</li>
</ul>
<p>工具</p>
<ul>
<li><a href="/zh-CN/docs/Tools/Performance">Firefox 开发者工具中的性能面板</a></li>
<li>火焰图</li>
<li>网络面板</li>
<li>瀑布图</li>
</ul>
<p>其他指标</p>
<ul>
<li>速度指数(Speed Index)和感知速度指数(Perceptual Speed Index)</li>
</ul>
<p>最佳实践</p>
<ul>
<li><a href="/zh-CN/docs/Web/API/Service_Worker_API/Using_Service_Workers">使用 Service Workers</a></li>
<li><a href="/zh-CN/docs/Web/API/Web_Workers_API/Using_web_workers">使用 Web Workers</a>
<ul>
<li><a href="/zh-CN/docs/Web/API/Web_Workers_API">Web Workers API</a></li>
</ul>
</li>
<li><a href="/zh-CN/docs/Web/Apps/Progressive/Offline_Service_workers">PWA</a></li>
<li><a href="/zh-CN/docs/Web/HTTP/Caching">缓存</a></li>
<li>内容分发网络 (CDN)</li>
</ul>
|