--- title: Performance API slug: Web/API/Performance_API tags: - web性能 - 性能 translation_of: Web/API/Performance_API ---
高时间采样率标准定义了{{domxref("Performance")}}接口,该接口支持应用程序中客户端的延时测量。{{domxref("Performance")}}接口被认为是高采样率的,因为其精确度可达千分之一毫秒(受硬件或软件限制)。这些接口支持许多使用情形,包括计算帧速率(在动画中可能很重要)和基准测试(例如加载资源的时间)。
由于平台的系统时钟会受到各种时滞(例如NTP调整)的影响,该接口支持单调时钟,即一直增加的时钟。 鉴于这个原因,Performance API定义了{{domxref("DOMHighResTimeStamp")}}类型,而不是使用{{jsxref("Date.now","Date.now()")}}接口。
{{domxref("DOMHighResTimeStamp")}}类型,顾名思义,表示高采样率的时间戳。 此类型是 double
,由性能接口使用。 该值可以是离散时间戳,也可以是两个离散时间戳之间的时间间隔。
DOMHighResTimeStamp
的单位是毫秒,应精确到5 µs(微秒)。 但是,如果浏览器无法提供精确到5微秒的时间数值(例如由于硬件或软件限制),则浏览器可以将该值表示为精确到毫秒的时间(以毫秒为单位)。
{{domxref("Performance")}}
接口具有两个方法。
{{domxref("Performance.now","now()")}} 方法返回一个{{domxref("DOMHighResTimeStamp")}},其值取决于{{domxref("PerformanceTiming.navigationStart","navigation start")}}和作用域。如果作用域是window,则值是创建浏览器上下文的时间;如果作用域是{{domxref("Worker","worker")}},则值是创建worker的时间。
{{domxref("Performance.toJSON","toJSON()")}}方法返回{{domxref("Performance")}}对象的序列化结果,包含可以被序列化的属性。
{{domxref("Performance")}}
接口具有两个属性。
{{domxref("Performance.timing","timing")}}属性返回一个{{domxref("PerformanceTiming")}}对象,其中包含与延时相关的性能信息,例如导航开始的时间,重定向的开始时间和结束时间,响应的开始时间和结束时间等。
{{domxref("Performance.navigation","navigation")}}
属性返回一个{{domxref("PerformanceNavigation")}}对象,该对象表示在给定浏览上下文中发生的导航类型,例如从历史记录导航到的页面,通过跟随链接导航到的页面等。
mark
"的{{domxref('PerformanceEntry')}}抽象接口,该类型的条目通过调用{{domxref("Performance.mark","mark()")}}将命名的{{domxref("DOMHighResTimeStamp")}}(mark)添加到浏览器的性能时间轴来创建。measure
"的{{domxref('PerformanceEntry')}}抽象接口,该类型的条目通过调用{{domxref("Performance.measure","measure()")}}在浏览器的性能时间轴的两个标记之间添加一个命名的{{domxref("DOMHighResTimeStamp")}}(measure)来创建。技术指标 | 状态 | 备注 |
---|---|---|
{{SpecName('Highres Time')}} | {{Spec2('Highres Time')}} | Initial definition. |
{{SpecName('Highres Time Level 2')}} | {{Spec2('Highres Time Level 2')}} | Adds performance attribute on Window and WorkerGlobalScope . |
{{SpecName('Highres Time Level 3')}} | {{Spec2('Highres Time Level 3')}} | Add timeOrigin property to Performance interface. |
{{SpecName('Frame Timing')}} | {{Spec2('Frame Timing')}} | Adds PerformanceFrameTiming interface. |
{{SpecName('Navigation Timing')}} | {{Spec2('Navigation Timing')}} | Adds the PerformanceTiming and PerformanceNavigation interfaces. Adds timing and navigation properties to the Performance interface. |
{{SpecName('Navigation Timing Level 2')}} | {{Spec2('Navigation Timing Level 2')}} | Adds the PerformanceNavigationTiming interface. Obsolete's the the PerformanceTiming interface, the PerformanceNavigation interface, as well as the timing and navigation properties to the Performance interface. |
{{SpecName('Performance Timeline')}} | {{Spec2('Performance Timeline')}} | Adds the PerformanceEntry interface, the PerformanceEntryList type, as well as the getEntries() , getEntriesByType() , and getEntriesByName() methods on the Performance interface. |
{{SpecName('Performance Timeline Level 2')}} | {{Spec2('Performance Timeline Level 2')}} | Adds serializer to the PerformanceEntry interface as well as adding the PerformanceObserver interface and callback |
{{SpecName('Resource Timing')}} | {{Spec2('Resource Timing')}} | Adds the PerformanceResourceTiming interface. Adds the clearResourceTimings() method, the setResourceTimingBufferSize() method, and the onresourcetimingbufferfull event handler to the Performance interface. Also adds the Timing-Allow-Origin response header. |
{{SpecName('Resource Timing 2')}} | {{Spec2('Resource Timing 2')}} | Adds the nextHopProtocol , workerStart , transferSize , encodedBodySize , and decodedBodySize properties to the PerformanceResourceTiming interface. |
{{SpecName('Resource Timing 3')}} | {{Spec2('Resource Timing 3')}} | |
{{SpecName('User Timing')}} | {{Spec2('User Timing')}} | Adds mark() , clearMarks() , measure() and clearMeasures() methods to the Performance interface. Adds the PerformanceMark and PeformanceMeasure interfaces. |
{{SpecName('User Timing Level 2')}} | {{Spec2('User Timing Level 2')}} |
As shown in the {{domxref("Performance")}} interface's Browser Compatibility table, most of these interfaces are broadly implemented by desktop browsers.
如{{domxref("Performance")}}接口的“浏览器兼容性”表所示,大部分接口由桌面浏览器广泛实现。
要测试你的浏览器对{{domxref("Performance")}}接口的支持,请运行 perf-api-support
应用。