Tested 2024-11-21 03:58:51 using Chrome 131.0.6778.69 (runtime settings).
Metric | Value |
---|---|
Page metrics | |
Performance score | 88 |
Total page size | 221.5 KB |
Requests | 15 |
Timing metrics | |
TTFB | 659 ms |
First Paint | 1.425 s |
Fully Loaded | 1.682 s |
Google Web Vitals | |
TTFB | 659 ms |
First Contentful Paint (FCP) | 1.425 s |
Largest Contentful Paint (LCP) | 1.425 s |
Cumulative Layout Shift (CLS) | 0.00 |
392 ms | |
CPU metrics | |
CPU long tasks | 1 |
CPU last long task happens at | 1.262 s |
Visual Metrics | |
First Visual Change | 1.433 s |
Speed Index | 1.438 s |
Visual Complete 85% | 1.433 s |
Visual Complete 99% | 1.566 s |
Last Visual Change | 1.733 s |
Use--filmstrip.showAll
to show all filmstrips.
The coach helps you find performance problems on your web page using web performance best practice rules. And gives you advice on privacy and best practices. Tested using Coach-core version 8.0.2.
Title | Advice | Score | |||||||||
---|---|---|---|---|---|---|---|---|---|---|---|
Avoid CPU Long Tasks (longTasks) | The page has 1 CPU long task with the total of 89 ms. The total blocking time is 0 ms and 1 long task before first contentful paint with total time of 89 ms. However the CPU Long Task is depending on the computer/phones actual CPU speed, so you should measure this on the same type of the device that your user is using. Use Geckoprofiler for Firefox or Chromes tracelog to debug your long tasks. | 80 | |||||||||
Description: Long CPU tasks locks the thread. To the user this is commonly visible as a "locked up" page where the browser is unable to respond to user input; this is a major source of bad user experience on the web today. However the CPU Long Task is depending on the computer/phones actual CPU speed, so you should measure this on the same type of the device that your user is using. To debug you should use the Chrome timeline log and drag/drop it into devtools or use Firefox Geckoprofiler. | |||||||||||
Offenders: | |||||||||||
Avoid extra requests by setting cache headers (cacheHeaders) | The page has 4 requests that are missing a cache time. Configure a cache time so the browser doesn't need to download them every time. It will save NaN undefined the next access. | 60 | |||||||||
Description: The easiest way to make your page fast is to avoid doing requests to the server. Setting a cache header on your server response will tell the browser that it doesn't need to download the asset again during the configured cache time! Always try to set a cache time if the content doesn't change for every request. | |||||||||||
Offenders: | |||||||||||
Long cache headers is good (cacheHeadersLong) | The page has 9 requests that have a shorter cache time than 30 days (but still a cache time). | 91 | |||||||||
Description: Setting a cache header is good. Setting a long cache header (at least 30 days) is even better beacause then it will stay long in the browser cache. But what do you do if that asset change? Rename it and the browser will pick up the new version. | |||||||||||
Offenders: | |||||||||||
Total JavaScript size shouldn't be too big (javascriptSize) | The total JavaScript transfer size is 167 kB and the uncompressed size is 524.2 kB. This is quite large. | 0 | |||||||||
Description: A lot of JavaScript often means you are downloading more than you need. How complex is the page and what can the user do on the page? Do you use multiple JavaScript frameworks? | |||||||||||
Offenders:
| |||||||||||
Make each CSS response small (optimalCssSize) | https://query.wikidata.org/querybuilder/assets/index.e0b88c88.css size is 39.8 kB (39773) and that is bigger than the limit of 14.5 kB. Try to make the CSS files fit into 14.5 KB. | 90 | |||||||||
Description: Make CSS responses small to fit into the magic number TCP window size of 14.5 KB. The browser can then download the CSS faster and that will make the page start rendering earlier. | |||||||||||
Offenders:
| |||||||||||
Avoid missing and error requests (responseOk) | The page has 4 error responses. The page has 4 responses with code 404. | 60 | |||||||||
Description: Your page should never request assets that return a 400 or 500 error. These requests are never cached. If that happens something is broken. Please fix it. | |||||||||||
Offenders: |
Title | Advice | Score |
---|---|---|
Set a referrer-policy header to make sure you do not leak user information. (referrerPolicyHeader) | Set a referrer-policy header to make sure you do not leak user information. | 0 |
Description: Referrer Policy is a new header that allows a site to control how much information the browser includes with navigations away from a document and should be set by all sites. https://scotthelme.co.uk/a-new-security-header-referrer-policy/. | ||
Offenders: |
Page info | |
---|---|
Title | Wikidata Query Builder |
Width | 1904 |
Height | 1225 |
DOM elements | 917 |
Avg DOM depth | 11 |
Max DOM depth | 26 |
Iframes | 0 |
Script tags | 1 |
Local storage | 0 b |
Session storage | 0 b |
Network Information API | 4g |
Data collected using Wappalyzerversion 6.10.66.
Use --browsertime.firefox.includeResponseBodies html
or --browsertime.chrome.includeResponseBodies html
to help Wappalyser find more information about technologies used.
Technology | Confidence | Category |
---|---|---|
Apache HTTP Server | 100 | Web servers |
HSTS | 100 | Security |
Visual Metrics | |
---|---|
First Visual Change | 1.433 s |
Speed Index | 1.438 s |
LargestContentfulPaint | 1.433 s |
Last Meaningful Paint | 1.433 s |
Largest Contentful Paint | 1.433 s |
Visual Complete 85% | 1.433 s |
Visual Complete 95% | 1.433 s |
Visual Complete 99% | 1.566 s |
Last Visual Change | 1.733 s |
Visual Readiness | 300 ms |
Navigation Timing | |
---|---|
backEndTime | 659 ms |
domContentLoadedTime | 1.162 s |
domInteractiveTime | 669 ms |
domainLookupTime | 107 ms |
frontEndTime | 502 ms |
pageDownloadTime | 1 ms |
pageLoadTime | 1.162 s |
redirectionTime | 0 ms |
serverConnectionTime | 203 ms |
serverResponseTime | 346 ms |
Google Web Vitals | |
---|---|
Time to first byte (TTFB) | 659 ms |
First Contentful Paint (FCP) | 1.425 s |
Largest Contentful Paint (LCP) | 1.425 s |
Interaction to next paint (INP) | 392 ms |
Total Blocking Time (TBT) | 0 ms |
First Contentful Paint info | |
---|---|
Elements that needed recalculate style before FCP | 388 |
Time spent in recalculate style before FCP | 18.968 ms |
Extra timings | |
---|---|
TTFB | 659 ms |
First Paint | 1.425 s |
Load Event End | 1.162 s |
Fully loaded | 1.682 s |
When in time the page main content is rendered (collected using the Largest Contentful Paint API). Read more about Largest Contentful Paint.
Element type | P |
Element/tag | <p class="querybuilder__description"></p> |
Render time | 1.425 s |
Elements that needed recalculate style before LCP | 388 |
Time spent in recalculate style before LCP | 18.968 ms |
Load time | 0 ms |
Size (width*height) | 75032 |
DOM path | |
div#app > div > main > p> div#app > div > main > p> |
No layout shift detected.
Interaction to Next Paint (INP) is a metric that try to measure responsiveness. It's useful if you are testing user journeys. Read more about Interaction to Next Paint.
The measured latency was 392 ms.
Event type | pointerover |
Element type | HTML |
Element class name | |
Event target | html |
Load state when the event happened | dom-interactive |
Read more about the Long Animation Frames API here here.
The top 10 longest animation frames entries
Blocking duration | Work duration | Render duration | PreLayout Duration | Style And Layout Duration |
---|---|---|---|---|
70 ms | 90.5 ms | 30.5 ms | 0 ms | 30.5 ms |
https://query.wikidata.org/querybuilder/assets/index.df3b4cfb.js | ||||
Forced Style And Layout Duration: 15 ms Invoker: Response.json.then |
Blocking duration | Work duration | Render duration | PreLayout Duration | Style And Layout Duration |
---|---|---|---|---|
0 ms | 361 ms | 3 ms | 0.1 ms | 2.9 ms |
No availible script information. |
name | duration | description |
---|---|---|
cache | 0 | hit-front |
host | 0 | cp3067 |
There are no custom configured scripts.
There are no custom extra metrics from scripting.
name | value |
---|---|
AudioHandlers | 0 |
AudioWorkletProcessors | 0 |
Documents | 14 |
Frames | 6 |
JSEventListeners | 765 |
LayoutObjects | 294 |
MediaKeySessions | 0 |
MediaKeys | 0 |
Nodes | 1856 |
Resources | 15 |
ContextLifecycleStateObservers | 15 |
V8PerContextDatas | 3 |
WorkerGlobalScopes | 0 |
UACSSResources | 0 |
RTCPeerConnections | 0 |
ResourceFetchers | 14 |
AdSubframes | 0 |
DetachedScriptStates | 2 |
ArrayBufferContents | 0 |
LayoutCount | 6 |
RecalcStyleCount | 22 |
LayoutDuration | 29 |
RecalcStyleDuration | 21 |
DevToolsCommandDuration | 40 |
ScriptDuration | 45 |
V8CompileDuration | 0 |
TaskDuration | 275 |
TaskOtherDuration | 142 |
ThreadTime | 1 |
ProcessTime | 2 |
JSHeapUsedSize | 6577236 |
JSHeapTotalSize | 10510336 |
FirstMeaningfulPaint | 1425 |
Name | Display Time | X | Y | Width | Height |
---|---|---|---|---|---|
Heading | 256 | 48 | 1 | 1 | |
<h1 class="visually-hidden"></h1> | |||||
LargestContentfulPaint | 1.433 s | 256 | 137 | 672 | 120 |
<p class="querybuilder__description"></p> |
How the page is built.
Summary | |
---|---|
HTTP version | HTTP/2.0 |
Total requests | 15 |
Total domains | 2 |
Total transfer size | 221.5 KB |
Total content size | 892.3 KB |
Responses missing compression | 6 |
Number of cookies | 1 |
Third party cookies | 0 |
Requests per response code | |
---|---|
200 | 10 |
204 | 1 |
404 | 4 |
URL | Type | Transfer Size | Content Size |
---|---|---|---|
https://query.wikida...endor.5730e773.js | javascript | 141.8 KB | 425.9 KB |
https://query.wikida...ndex.e0b88c88.css | css | 38.8 KB | 346.7 KB |
https://query.wikida...index.df3b4cfb.js | javascript | 21.4 KB | 86.0 KB |
https://query.wikidata.org/favicon.ico | favicon | 5.5 KB | 14.7 KB |
https://query.wikida...r/img/QB_Logo.svg | svg | 4.2 KB | 7.6 KB |
https://query.wikida...lder/i18n/en.json | json | 3.1 KB | 7.3 KB |
https://query.wikidata.org/querybuilder/ | html | 2.0 KB | 2.2 KB |
https://query.wikida...der/img/clear.svg | svg | 1.4 KB | 1.0 KB |
https://query.wikida...er/img/search.svg | svg | 1.3 KB | 494 B |
https://query.wikida...der/img/close.svg | svg | 1.2 KB | 321 B |
https://www.wikidata...org/beacon/statsv | plain | 754 B | 0 b |
https://query.wikida...wikit-Icon-513017 | html | N/A | 0 b |
https://query.wikida.../wikit-Icon-31384 | html | N/A | 0 b |
https://query.wikida...wikit-Icon-221290 | html | N/A | 0 b |
https://query.wikida...wikit-Icon-473404 | html | N/A | 0 b |
Content | Header Size | Transfer Size | Content Size | Requests |
---|---|---|---|---|
html | 0 b | 2.0 KB | 2.2 KB | 1 |
css | 0 b | 38.8 KB | 346.7 KB | 1 |
javascript | 0 b | 163.1 KB | 511.9 KB | 2 |
json | 0 b | 3.1 KB | 7.3 KB | 1 |
favicon | 0 b | 5.5 KB | 14.7 KB | 1 |
plain | 0 b | 754 B | 0 b | 1 |
svg | 0 b | 8.1 KB | 9.4 KB | 4 |
Total | 0 b | 221.5 KB | 892.3 KB | 11 |
Domain | Total download time | Transfer Size | Content Size | Requests |
---|---|---|---|---|
query.wikidata.org | 3.519 s | 220.8 KB | 892.3 KB | 14 |
www.wikidata.org | 206 ms | 754 B | 0 b | 1 |
type | min | median | max |
---|---|---|---|
Expires | 0 seconds | 1 hour | 1 hour |
Last modified | 34 weeks | 1 year | 2 years |
The page logs the following messages to the console.
Level | Message |
---|---|
SEVERE | https://query.wikidata.org/querybuilder/wikit-Icon-221290 - Failed to load resource: the server responded with a status of 404 () |
SEVERE | https://query.wikidata.org/querybuilder/wikit-Icon-513017 - Failed to load resource: the server responded with a status of 404 () |
SEVERE | https://query.wikidata.org/querybuilder/wikit-Icon-31384 - Failed to load resource: the server responded with a status of 404 () |
SEVERE | https://query.wikidata.org/querybuilder/wikit-Icon-473404 - Failed to load resource: the server responded with a status of 404 () |
Included requests done after load event end.
Content | Transfer Size | Requests |
---|---|---|
html | 0 b | 0 |
css | 0 b | 0 |
javascript | 0 b | 0 |
image | 0 b | 0 |
font | 0 b | 0 |
favicon | 5.5 KB | 1 |
plain | 754 B | 1 |
svg | 8.1 KB | 4 |
Total | 14.4 KB | 10 |
Includes requests done after DOM content loaded.
Content | Transfer Size | Requests |
---|---|---|
html | 0 b | 0 |
css | 0 b | 0 |
javascript | 0 b | 0 |
image | 0 b | 0 |
font | 0 b | 0 |
favicon | 5.5 KB | 1 |
plain | 754 B | 1 |
svg | 8.1 KB | 4 |
Total | 14.4 KB | 10 |
Render blocking information directly from Chrome.
Blocking | In body parser blocking | Potentially blocking |
---|---|---|
1 | 0 | 0 |
URL | Type |
---|---|
https://query.wikida...endor.5730e773.js | non_blocking |
https://query.wikida...ndex.e0b88c88.css | blocking |
https://query.wikida...index.df3b4cfb.js | non_blocking |
Download the Chrome trace log and drag and drop it into Developer Tools / Performance in Chrome.
Collected using the Long Task API. A long task is a task that take 50 milliseconds or more.
Type | Quantity | Total duration (ms) |
---|---|---|
Total Blocking Time | 0 | |
Max Potential First Input Delay | 0 | |
Long Tasks before First Paint | 1 | 89 |
Long Tasks before First Contentful Paint | 1 | 89 |
Long Tasks before Largest Contentful Paint | 1 | 89 |
Long Tasks after Load Event End | 1 | 89 |
Total Long Tasks | 1 | 89 |
CPU last long task happened at 1.262 s
name | startTime | duration | containerId | containerName | containerSrc | containerType |
---|---|---|---|---|---|---|
unknown | 1262 | 89 | window |
Calculated using Tracium.
Categories (ms) | |
---|---|
parseHTML | 7 |
styleLayout | 50 |
paintCompositeRender | 5 |
scriptParseCompile | 1 |
scriptEvaluation | 112 |
garbageCollection | 7 |
other | 61 |
Events (ms) | |
---|---|
RunMicrotasks | 66 |
v8.evaluateModule | 38 |
RunTask | 37 |
Layout | 29 |
UpdateLayoutTree | 20 |
CpuProfiler::StartProfiling | 14 |
afterPageCompleteCheck.jpg
layoutShift.jpg
largestContentfulPaint.jpg