Tested using Chrome 102.0.5005.61 (runtime settings).
| Metric | Value |
|---|---|
| Page metrics | |
| Performance score | 62 |
| Total page size | 2.2 MB |
| Requests | 39 |
| Timing metrics | |
| TTFB | 115 ms |
| First Paint | 463 ms |
| Fully Loaded | 1.547 s |
| Google Web Vitals | |
| TTFB | 115 ms |
| First Contentful Paint (FCP) | 463 ms |
| Largest Contentful Paint (LCP) | 463 ms |
| Cumulative Layout Shift (CLS) | 0.00 |
| Total Blocking Time | 272 ms |
| Max Potential FID | 205 ms |
| CPU metrics | |
| CPU long tasks | 7 |
| CPU last long task happens at | 1.297 s |
| Visual Metrics | |
| First Visual Change | 702 ms |
| Speed Index | 899 ms |
| Visual Complete 85% | 1.438 s |
| Visual Complete 99% | 1.438 s |
| Last Visual Change | 1.505 s |
Use--filmstrip.showAll to show all filmstrips.
1.5 sGTM-G-8LHNSPWCG8:container_execute_start 1.436 sGTM-G-8LHNSPWCG8:0:event_setup_start 1.438 sVisual Complete 85% 1.438 sVisual Complete 95% 1.438 sVisual Complete 99% 1.438 sGTM-G-8LHNSPWCG8:0:event_evaluation_start 1.439 sGTM-G-8LHNSPWCG8:0:event_evaluation_end 1.442 sGTM-G-8LHNSPWCG8:0:event_setup_end 1.442 sGTM-G-8LHNSPWCG8:0:108:tag_execute_start 1.443 sGTM-G-8LHNSPWCG8:0:108:tag_execute_end 1.447 sThe 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.
| Title | Advice | Score | ||||||||||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
| Don't scale images in the browser (avoidScalingImages) | The page has 8 images that are scaled more than 100 pixels. It would be better if those images are sent so the browser don't need to scale them. | 20 | ||||||||||||||||||
| Description: It's easy to scale images in the browser and make sure they look good in different devices, however that is bad for performance! Scaling images in the browser takes extra CPU time and will hurt performance on mobile. And the user will download extra kilobytes (sometimes megabytes) of data that could be avoided. Don't do that, make sure you create multiple version of the same image server-side and serve the appropriate one. | ||||||||||||||||||||
| Offenders: | ||||||||||||||||||||
| Avoid using Google Tag Manager. (googleTagManager) | The page is using Google Tag Manager, this is a performance risk since non-tech users can add JavaScript to your page. | 0 | ||||||||||||||||||
| Description: Google Tag Manager makes it possible for non tech users to add scripts to your page that will downgrade performance. | ||||||||||||||||||||
| Inline CSS for faster first render (inlineCss) | The page loads 3 CSS requests inside of head, try to inline the CSS for the first render and lazy load the rest. | 70 | ||||||||||||||||||
| Description: In the early days of the Internet, inlining CSS was one of the ugliest things you can do. That has changed if you want your page to start rendering fast for your user. Always inline the critical CSS when you use HTTP/1 and HTTP/2 (avoid doing CSS requests that block rendering) and lazy load and cache the rest of the CSS. It is a little more complicated when using HTTP/2. Does your server support HTTP push? Then maybe that can help. Do you have a lot of users on a slow connection and are serving large chunks of HTML? Then it could be better to use the inline technique, becasue some servers always prioritize HTML content over CSS so the user needs to download the HTML first, before the CSS is downloaded. | ||||||||||||||||||||
| Offenders: | ||||||||||||||||||||
| Avoid CPU Long Tasks (longTasks) | The page has 7 CPU long tasks with the total of 653 ms. The total blocking time is 272 ms and 1 long task before first contentful paint with total time of 81 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. | 0 | ||||||||||||||||||
| 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 Frontend single point of failures (spof) | The page has 2 requests inside of the head that can cause a SPOF (single point of failure). Load them asynchronously or move them outside of the document head. | 80 | ||||||||||||||||||
| Description: A page can be stopped from loading in the browser if a single JavaScript, CSS, and in some cases a font, couldn't be fetched or is loading really slowly (the white screen of death). That is a scenario you really want to avoid. Never load 3rd-party components synchronously inside of the head tag. | ||||||||||||||||||||
| Offenders: | ||||||||||||||||||||
| Avoid extra requests by setting cache headers (cacheHeaders) | The page has 13 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 37.3 kB the next access. | 0 | ||||||||||||||||||
| 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 16 requests that have a shorter cache time than 30 days (but still a cache time). | 84 | ||||||||||||||||||
| 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: | ||||||||||||||||||||
| Always compress text content (compressAssets) | The page has 4 requests that are served uncompressed. You could save a lot of bytes by sending them compressed instead. | 60 | ||||||||||||||||||
| Description: In the early days of the Internet there were browsers that didn't support compressing (gzipping) text content. They do now. Make sure you compress HTML, JSON, JavaScript, CSS and SVG. It will save bytes for the user; making the page load faster and use less bandwith. | ||||||||||||||||||||
Offenders:
| ||||||||||||||||||||
| Avoid too many fonts (fewFonts) | The page has 2 font requests. Do you really need them? What value does the fonts give the user? | 80 | ||||||||||||||||||
| Description: How many fonts do you need on a page for the user to get the message? Fonts can slow down the rendering of content, try to avoid loading too many of them because worst case it can make the text invisible until they are loaded (FOIT—flash of invisible text), best case they will flicker the text content when they arrive. | ||||||||||||||||||||
| Offenders: | ||||||||||||||||||||
| Total image size shouldn't be too big (imageSize) | The page total image size is 1.5 MB. It's really big. Is the page using the right format for the images? Can they be lazy loaded? Are they compressed as good as they can be? Make them smaller by using https://imageoptim.com/. | 50 | ||||||||||||||||||
| Description: Avoid having too many large images on the page. The images will not affect the first paint of the page, but it will eat bandwidth for the user. | ||||||||||||||||||||
| Total JavaScript size shouldn't be too big (javascriptSize) | The total JavaScript transfer size is 661.7 kB and the uncompressed size is 2 MB. This is totally crazy! There is really room for improvement here. | 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:
| ||||||||||||||||||||
| Avoid using incorrect mime types (mimeTypes) | The page has 3 misconfigured mime types. | 97 | ||||||||||||||||||
| Description: It's not a great idea to let browsers guess content types (content sniffing), in some cases it can actually be a security risk. | ||||||||||||||||||||
| Offenders: | ||||||||||||||||||||
| Make each CSS response small (optimalCssSize) | https://www.scottish-enterprise.com/assets/styles/site.css?v=0.218.0.0 size is 62 kB (62001) 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:
| ||||||||||||||||||||
| Total page size shouldn't be too big (pageSize) | The page total transfer size is 2.4 MB, which is more than the coach limit of 2 MB. That is really big and you need to make it smaller. | 0 | ||||||||||||||||||
| Description: Avoid having pages that have a transfer size over the wire of more than 2 MB (desktop) and 1 MB (mobile) because that is really big and will hurt performance and will make the page expensive for the user if she/he pays for the bandwidth. | ||||||||||||||||||||
| Offenders: | ||||||||||||||||||||
| Don't use private headers on static content (privateAssets) | The page has 5 requests with private headers. Make sure that the assets really should be private and only used by one user. Otherwise, make it cacheable for everyone. | 50 | ||||||||||||||||||
| Description: If you set private headers on content, that means that the content are specific for that user. Static content should be able to be cached and used by everyone. Avoid setting the cache header to private. | ||||||||||||||||||||
| Offenders: | ||||||||||||||||||||
| Title | Advice | Score |
|---|---|---|
| Meta description (metaDescription) | The meta description is too long. It has 157 characters, the recommended max is 155 | 50 |
| Description: Use a page description to make the page more relevant to search engines. | ||
| Page title (pageTitle) | The title is too long by 7 characters. The recommended max is 60 | 50 |
| Description: Use a title to make the page more relevant to search engines. | ||
| Do not send too long headers (longHeaders) | https://www.scottish-enterprise.com/ has a header set-cookie that is 2040 characters long. | 99 |
| Description: Do not send response headers that are too long. | ||
| Offenders: | ||
| Avoid too many third party requests (thirdParty) | The page do 33% requests to third party domains (13 requests and 473.4 kB). First party is 26 requests and 1.9 MB. The regex .*scottish-enterprise.* was used to calculate first/third party requests. | 50 |
| Description: Do not load most of your content from third party URLs. | ||
| Avoid unnecessary headers (unnecessaryHeaders) | There are 5 responses that sets both a max-age and expires header. There are 12 responses that sets a server header. | 83 |
| Description: Do not send headers that you don't need. We look for p3p, cache-control and max-age, pragma, server and x-frame-options headers. Have a look at Andrew Betts - Headers for Hackers talk as a guide https://www.youtube.com/watch?v=k92ZbrY815c or read https://www.fastly.com/blog/headers-we-dont-want. | ||
| Offenders: | ||
| Title | Advice | Score |
|---|---|---|
| Use a good Content-Security-Policy header to make sure you you avoid Cross Site Scripting (XSS) attacks. (contentSecurityPolicyHeader) | Set a Content-Security-Policy header to make sure you are not open for Cross Site Scripting (XSS) attacks. You can start with setting a Content-Security-Policy-Report-Only header, that will only report the violation, not stop the download. | 0 |
| Description: Content Security Policy is delivered via a HTTP response header, and defines approved sources of content that the browser may load. It can be an effective countermeasure to Cross Site Scripting (XSS) attacks and is also widely supported and usually easily deployed. https://scotthelme.co.uk/content-security-policy-an-introduction/. | ||
| Offenders: | ||
| Set a permission policy header that opt out your users being tracked in Chrome by FLoC. (disableFLoCHeader) | Set a permission policy header that opt out Chrome for tracking what your users do on your site. | 0 |
| Description: Googles new tracking method is called Federated Learning of Cohorts (FLoC) and it groups you based on your interests and demographics, derived from your browsing history, to enable creepy advertising and other content targeting without third-party cookies. You can avoid that by setting a Permissions-Policy header with the value of interest-cohort=(). See https://www.eff.org/deeplinks/2021/03/googles-floc-terrible-idea. | ||
| Offenders: | ||
| Set a strict transport header to make sure the user always use HTTPS. (strictTransportSecurityHeader) | A strict transport header is set but miss out on setting includeSubDomains | 90 |
| Description: The HTTP Strict-Transport-Security response header (often abbreviated as HSTS) lets a web site tell browsers that it should only be accessed using HTTPS, instead of using HTTP. https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Strict-Transport-Security. | ||
| Do not share user data with third parties. (thirdPartyPrivacy) | The page has 23% requests that are 3rd party (9 requests with a size of 415.2 kB). The page also have request to companies that harvest data from users and do not respect users privacy (see https://en.wikipedia.org/wiki/Surveillance_capitalism). The page do 6 survelliance requests and uses 2 survelliance tools. The page do 4 tag-manager requests and uses 1 tag-manager tool. | 0 |
| Description: Using third party requests shares user information with that third party. Please avoid that! The project https://github.com/patrickhulce/third-party-web is used to categorize first/third party requests. | ||
| Offenders: | ||
| Page info | |
|---|---|
| Title | Support and advice for businesses in Scotland | Scottish Enterprise |
| Width | 1365 |
| Height | 4679 |
| DOM elements | 1266 |
| Avg DOM depth | 15 |
| Max DOM depth | 23 |
| Iframes | 0 |
| Script tags | 9 |
| Local storage | 0 b |
| Session storage | 1.5 KB |
| HTML vs AMP | Plain good HTML page |
| Resource Hints |
|---|
| preconnect |
| https://fonts.googleapis.com/ |
| https://fonts.gstatic.com/ |
Data collected using Wappalyzer. Use --browsertime.firefox.includeResponseBodies htmlor --browsertime.chrome.includeResponseBodies htmlto help Wappalyser find more information about technologies used.
| Technology | Confidence | Category |
|---|---|---|
| Google Tag Manager | 100 | Tag managers |
| Google Analytics | 100 | Analytics |
Data collected using Third Party Web.
| Cdn |
|---|
| Google Fonts |
| Adobe TypeKit |
| Survelliance |
| Google Fonts |
| Google Tag Manager |
| Tag-manager |
| Google Tag Manager |
| Visual Metrics | |
|---|---|
| First Visual Change | 702 ms |
| Speed Index | 899 ms |
| Visual Complete 85% | 1.438 s |
| Visual Complete 95% | 1.438 s |
| Visual Complete 99% | 1.438 s |
| Last Visual Change | 1.505 s |
| Visual Readiness | 803 ms |
| Navigation Timing | |
|---|---|
| backEndTime | 115 ms |
| domContentLoadedTime | 831 ms |
| domInteractiveTime | 362 ms |
| domainLookupTime | 0 ms |
| frontEndTime | 859 ms |
| pageDownloadTime | 9 ms |
| pageLoadTime | 983 ms |
| redirectionTime | 0 ms |
| serverConnectionTime | 24 ms |
| serverResponseTime | 91 ms |
| Google Web Vitals | |
|---|---|
| Time to first byte (TTFB) | 115 ms |
| First Contentful Paint (FCP) | 463 ms |
| Largest Contentful Paint (LCP) | 463 ms |
| Cumulative Layout Shift (CLS) | 0.00 |
| Total Blocking Time (TBT) | 272 ms |
| Extra timings | |
|---|---|
| TTFB | 115 ms |
| First Paint | 463 ms |
| Load Event End | 983 ms |
| Fully loaded | 1.547 s |
| User Timing marks | |
|---|---|
| GTM-G-8LHNSPWCG8:page_load | 0 ms |
| GTM-G-8LHNSPWCG8:snippet_load | 169 ms |
| GTM-G-8LHNSPWCG8:container_setup_start | 1.330 s |
| GTM-G-8LHNSPWCG8:container_execute_start | 1.436 s |
| GTM-G-8LHNSPWCG8:0:event_setup_start | 1.438 s |
| GTM-G-8LHNSPWCG8:0:event_evaluation_start | 1.439 s |
| GTM-G-8LHNSPWCG8:0:event_evaluation_end | 1.442 s |
| GTM-G-8LHNSPWCG8:0:event_setup_end | 1.442 s |
| GTM-G-8LHNSPWCG8:0:108:tag_execute_start | 1.443 s |
| GTM-G-8LHNSPWCG8:0:108:tag_execute_end | 1.447 s |
| GTM-G-8LHNSPWCG8:0:111:tag_execute_start | 1.447 s |
| GTM-G-8LHNSPWCG8:0:111:tag_execute_end | 1.447 s |
| GTM-G-8LHNSPWCG8:1:event_setup_start | 1.448 s |
| GTM-G-8LHNSPWCG8:1:event_evaluation_start | 1.448 s |
| GTM-G-8LHNSPWCG8:1:event_evaluation_end | 1.449 s |
| GTM-G-8LHNSPWCG8:1:event_setup_end | 1.449 s |
| GTM-G-8LHNSPWCG8:1:106:tag_execute_start | 1.450 s |
| GTM-G-8LHNSPWCG8:1:106:tag_execute_end | 1.451 s |
| GTM-G-8LHNSPWCG8:1:110:tag_execute_start | 1.451 s |
| GTM-G-8LHNSPWCG8:1:110:tag_execute_end | 1.453 s |
| GTM-G-8LHNSPWCG8:1:128:tag_execute_start | 1.453 s |
| GTM-G-8LHNSPWCG8:1:128:tag_execute_end | 1.453 s |
| GTM-G-8LHNSPWCG8:1:127:tag_execute_start | 1.454 s |
| GTM-G-8LHNSPWCG8:1:127:tag_execute_end | 1.454 s |
| GTM-G-8LHNSPWCG8:1:126:tag_execute_start | 1.454 s |
| GTM-G-8LHNSPWCG8:1:126:tag_execute_end | 1.455 s |
| GTM-G-8LHNSPWCG8:1:125:tag_execute_start | 1.455 s |
| GTM-G-8LHNSPWCG8:1:125:tag_execute_end | 1.458 s |
| GTM-G-8LHNSPWCG8:1:124:tag_execute_start | 1.459 s |
| GTM-G-8LHNSPWCG8:1:124:tag_execute_end | 1.460 s |
| GTM-G-8LHNSPWCG8:1:123:tag_execute_start | 1.460 s |
| GTM-G-8LHNSPWCG8:1:123:tag_execute_end | 1.462 s |
| GTM-G-8LHNSPWCG8:1:122:tag_execute_start | 1.463 s |
| GTM-G-8LHNSPWCG8:1:122:tag_execute_end | 1.464 s |
| GTM-G-8LHNSPWCG8:1:121:tag_execute_start | 1.464 s |
| GTM-G-8LHNSPWCG8:1:121:tag_execute_end | 1.465 s |
| GTM-G-8LHNSPWCG8:1:120:tag_execute_start | 1.466 s |
| GTM-G-8LHNSPWCG8:1:120:tag_execute_end | 1.468 s |
| GTM-G-8LHNSPWCG8:1:119:tag_execute_start | 1.468 s |
| GTM-G-8LHNSPWCG8:1:119:tag_execute_end | 1.469 s |
| GTM-G-8LHNSPWCG8:1:118:tag_execute_start | 1.469 s |
| GTM-G-8LHNSPWCG8:1:118:tag_execute_end | 1.470 s |
| GTM-G-8LHNSPWCG8:1:117:tag_execute_start | 1.470 s |
| GTM-G-8LHNSPWCG8:1:117:tag_execute_end | 1.471 s |
| GTM-G-8LHNSPWCG8:1:116:tag_execute_start | 1.471 s |
| GTM-G-8LHNSPWCG8:1:116:tag_execute_end | 1.471 s |
| GTM-G-8LHNSPWCG8:1:115:tag_execute_start | 1.472 s |
| GTM-G-8LHNSPWCG8:1:115:tag_execute_end | 1.473 s |
| GTM-G-8LHNSPWCG8:1:114:tag_execute_start | 1.473 s |
| GTM-G-8LHNSPWCG8:1:114:tag_execute_end | 1.478 s |
| GTM-G-8LHNSPWCG8:1:113:tag_execute_start | 1.478 s |
| GTM-G-8LHNSPWCG8:1:113:tag_execute_end | 1.480 s |
| GTM-G-8LHNSPWCG8:1:112:tag_execute_start | 1.480 s |
| GTM-G-8LHNSPWCG8:1:112:tag_execute_end | 1.480 s |
| GTM-G-8LHNSPWCG8:2:event_setup_start | 1.481 s |
| GTM-G-8LHNSPWCG8:2:event_evaluation_start | 1.481 s |
| GTM-G-8LHNSPWCG8:2:event_evaluation_end | 1.481 s |
| GTM-G-8LHNSPWCG8:2:event_setup_end | 1.481 s |
| GTM-G-8LHNSPWCG8:2:104:tag_execute_start | 1.482 s |
| GTM-G-8LHNSPWCG8:2:104:tag_execute_end | 1.494 s |
| GTM-G-8LHNSPWCG8:7:event_setup_start | 1.496 s |
| GTM-G-8LHNSPWCG8:7:event_evaluation_start | 1.497 s |
| GTM-G-8LHNSPWCG8:7:event_evaluation_end | 1.497 s |
| GTM-G-8LHNSPWCG8:7:event_setup_end | 1.497 s |
| GTM-G-8LHNSPWCG8:8:event_setup_start | 1.500 s |
| GTM-G-8LHNSPWCG8:8:event_evaluation_start | 1.500 s |
| GTM-G-8LHNSPWCG8:8:event_evaluation_end | 1.500 s |
| GTM-G-8LHNSPWCG8:8:event_setup_end | 1.500 s |
| GTM-G-8LHNSPWCG8:9:event_setup_start | 1.501 s |
| GTM-G-8LHNSPWCG8:9:event_evaluation_start | 1.501 s |
| GTM-G-8LHNSPWCG8:9:event_evaluation_end | 1.501 s |
| GTM-G-8LHNSPWCG8:9:event_setup_end | 1.501 s |
| GTM-G-8LHNSPWCG8:container_blocking_end | 1.502 s |
| GTM-G-8LHNSPWCG8:container_setup_end | 1.503 s |
| GTM-G-8LHNSPWCG8:0:108:tag_callback_success | 1.516 s |
| GTM-G-8LHNSPWCG8:0:111:tag_callback_success | 1.516 s |
| GTM-G-8LHNSPWCG8:1:106:tag_callback_success | 1.516 s |
| GTM-G-8LHNSPWCG8:1:110:tag_callback_success | 1.516 s |
| GTM-G-8LHNSPWCG8:1:128:tag_callback_success | 1.517 s |
| GTM-G-8LHNSPWCG8:1:127:tag_callback_success | 1.517 s |
| GTM-G-8LHNSPWCG8:1:126:tag_callback_success | 1.517 s |
| GTM-G-8LHNSPWCG8:1:125:tag_callback_success | 1.517 s |
| GTM-G-8LHNSPWCG8:1:124:tag_callback_success | 1.517 s |
| GTM-G-8LHNSPWCG8:1:123:tag_callback_success | 1.518 s |
| GTM-G-8LHNSPWCG8:1:122:tag_callback_success | 1.519 s |
| GTM-G-8LHNSPWCG8:1:121:tag_callback_success | 1.519 s |
| GTM-G-8LHNSPWCG8:1:120:tag_callback_success | 1.526 s |
| GTM-G-8LHNSPWCG8:1:119:tag_callback_success | 1.526 s |
| GTM-G-8LHNSPWCG8:1:118:tag_callback_success | 1.527 s |
| GTM-G-8LHNSPWCG8:1:117:tag_callback_success | 1.527 s |
| GTM-G-8LHNSPWCG8:1:116:tag_callback_success | 1.527 s |
| GTM-G-8LHNSPWCG8:1:115:tag_callback_success | 1.527 s |
| GTM-G-8LHNSPWCG8:1:114:tag_callback_success | 1.527 s |
| GTM-G-8LHNSPWCG8:1:113:tag_callback_success | 1.527 s |
| GTM-G-8LHNSPWCG8:1:112:tag_callback_success | 1.527 s |
| GTM-G-8LHNSPWCG8:2:104:tag_callback_success | 1.527 s |
| GTM-G-8LHNSPWCG8:7:event_execute_end | 1.528 s |
| GTM-G-8LHNSPWCG8:8:event_execute_end | 1.528 s |
| GTM-G-8LHNSPWCG8:container_execute_end | 1.528 s |
| GTM-G-8LHNSPWCG8:9:event_execute_end | 1.534 s |
| GTM-G-8LHNSPWCG8:0:event_execute_end | 1.535 s |
| GTM-G-8LHNSPWCG8:1:event_execute_end | 1.535 s |
| GTM-G-8LHNSPWCG8:2:event_execute_end | 1.535 s |
| User Timing measures | ||
|---|---|---|
| Name | Start time | Duration |
| GTM-G-8LHNSPWCG8:page_load:to:snippet_load | 0 ms | 169 ms |
| GTM-G-8LHNSPWCG8:container_setup_start:to:container_setup_end | 1.330 s | 172 ms |
| GTM-G-8LHNSPWCG8:container_execute_start:to:container_blocking_end | 1.436 s | 67 ms |
| GTM-G-8LHNSPWCG8:container_execute_start:to:container_execute_end | 1.436 s | 93 ms |
| GTM-G-8LHNSPWCG8:0:event_setup_start:to:event_setup_end | 1.438 s | 4 ms |
| GTM-G-8LHNSPWCG8:0:event_setup_start:to:event_execute_end | 1.438 s | 97 ms |
| GTM-G-8LHNSPWCG8:0:event_evaluation_start:to:event_evaluation_end | 1.439 s | 3 ms |
| GTM-G-8LHNSPWCG8:0:108:tag_execute_start:to:tag_execute_end | 1.443 s | 3 ms |
| GTM-G-8LHNSPWCG8:0:108:tag_execute_start:to:tag_callback_success | 1.443 s | 73 ms |
| GTM-G-8LHNSPWCG8:0:111:tag_execute_start:to:tag_execute_end | 1.447 s | 1 ms |
| GTM-G-8LHNSPWCG8:0:111:tag_execute_start:to:tag_callback_success | 1.447 s | 69 ms |
| GTM-G-8LHNSPWCG8:1:event_setup_start:to:event_setup_end | 1.448 s | 1 ms |
| GTM-G-8LHNSPWCG8:1:event_setup_start:to:event_execute_end | 1.448 s | 88 ms |
| GTM-G-8LHNSPWCG8:1:event_evaluation_start:to:event_evaluation_end | 1.448 s | 1 ms |
| GTM-G-8LHNSPWCG8:1:106:tag_execute_start:to:tag_execute_end | 1.450 s | 1 ms |
| GTM-G-8LHNSPWCG8:1:106:tag_execute_start:to:tag_callback_success | 1.450 s | 67 ms |
| GTM-G-8LHNSPWCG8:1:110:tag_execute_start:to:tag_execute_end | 1.451 s | 1 ms |
| GTM-G-8LHNSPWCG8:1:110:tag_execute_start:to:tag_callback_success | 1.451 s | 65 ms |
| GTM-G-8LHNSPWCG8:1:128:tag_execute_start:to:tag_execute_end | 1.453 s | 1 ms |
| GTM-G-8LHNSPWCG8:1:128:tag_execute_start:to:tag_callback_success | 1.453 s | 64 ms |
| GTM-G-8LHNSPWCG8:1:127:tag_execute_start:to:tag_execute_end | 1.454 s | 1 ms |
| GTM-G-8LHNSPWCG8:1:127:tag_execute_start:to:tag_callback_success | 1.454 s | 63 ms |
| GTM-G-8LHNSPWCG8:1:126:tag_execute_start:to:tag_execute_end | 1.454 s | 1 ms |
| GTM-G-8LHNSPWCG8:1:126:tag_execute_start:to:tag_callback_success | 1.454 s | 63 ms |
| GTM-G-8LHNSPWCG8:1:125:tag_execute_start:to:tag_execute_end | 1.455 s | 3 ms |
| GTM-G-8LHNSPWCG8:1:125:tag_execute_start:to:tag_callback_success | 1.455 s | 62 ms |
| GTM-G-8LHNSPWCG8:1:124:tag_execute_start:to:tag_execute_end | 1.459 s | 2 ms |
| GTM-G-8LHNSPWCG8:1:124:tag_execute_start:to:tag_callback_success | 1.459 s | 59 ms |
| GTM-G-8LHNSPWCG8:1:123:tag_execute_start:to:tag_execute_end | 1.460 s | 2 ms |
| GTM-G-8LHNSPWCG8:1:123:tag_execute_start:to:tag_callback_success | 1.460 s | 57 ms |
| GTM-G-8LHNSPWCG8:1:122:tag_execute_start:to:tag_execute_end | 1.463 s | 2 ms |
| GTM-G-8LHNSPWCG8:1:122:tag_execute_start:to:tag_callback_success | 1.463 s | 56 ms |
| GTM-G-8LHNSPWCG8:1:121:tag_execute_start:to:tag_execute_end | 1.464 s | 1 ms |
| GTM-G-8LHNSPWCG8:1:121:tag_execute_start:to:tag_callback_success | 1.464 s | 55 ms |
| GTM-G-8LHNSPWCG8:1:120:tag_execute_start:to:tag_execute_end | 1.466 s | 2 ms |
| GTM-G-8LHNSPWCG8:1:120:tag_execute_start:to:tag_callback_success | 1.466 s | 61 ms |
| GTM-G-8LHNSPWCG8:1:119:tag_execute_start:to:tag_execute_end | 1.468 s | 1 ms |
| GTM-G-8LHNSPWCG8:1:119:tag_execute_start:to:tag_callback_success | 1.468 s | 58 ms |
| GTM-G-8LHNSPWCG8:1:118:tag_execute_start:to:tag_execute_end | 1.469 s | 1 ms |
| GTM-G-8LHNSPWCG8:1:118:tag_execute_start:to:tag_callback_success | 1.469 s | 58 ms |
| GTM-G-8LHNSPWCG8:1:117:tag_execute_start:to:tag_execute_end | 1.470 s | 1 ms |
| GTM-G-8LHNSPWCG8:1:117:tag_execute_start:to:tag_callback_success | 1.470 s | 57 ms |
| GTM-G-8LHNSPWCG8:1:116:tag_execute_start:to:tag_execute_end | 1.471 s | 1 ms |
| GTM-G-8LHNSPWCG8:1:116:tag_execute_start:to:tag_callback_success | 1.471 s | 56 ms |
| GTM-G-8LHNSPWCG8:1:115:tag_execute_start:to:tag_execute_end | 1.472 s | 1 ms |
| GTM-G-8LHNSPWCG8:1:115:tag_execute_start:to:tag_callback_success | 1.472 s | 55 ms |
| GTM-G-8LHNSPWCG8:1:114:tag_execute_start:to:tag_execute_end | 1.473 s | 5 ms |
| GTM-G-8LHNSPWCG8:1:114:tag_execute_start:to:tag_callback_success | 1.473 s | 54 ms |
| GTM-G-8LHNSPWCG8:1:113:tag_execute_start:to:tag_execute_end | 1.478 s | 2 ms |
| GTM-G-8LHNSPWCG8:1:113:tag_execute_start:to:tag_callback_success | 1.478 s | 49 ms |
| GTM-G-8LHNSPWCG8:1:112:tag_execute_start:to:tag_execute_end | 1.480 s | 0 ms |
| GTM-G-8LHNSPWCG8:1:112:tag_execute_start:to:tag_callback_success | 1.480 s | 47 ms |
| GTM-G-8LHNSPWCG8:2:event_setup_start:to:event_setup_end | 1.481 s | 1 ms |
| GTM-G-8LHNSPWCG8:2:event_setup_start:to:event_execute_end | 1.481 s | 55 ms |
| GTM-G-8LHNSPWCG8:2:event_evaluation_start:to:event_evaluation_end | 1.481 s | 0 ms |
| GTM-G-8LHNSPWCG8:2:104:tag_execute_start:to:tag_execute_end | 1.482 s | 13 ms |
| GTM-G-8LHNSPWCG8:2:104:tag_execute_start:to:tag_callback_success | 1.482 s | 46 ms |
| GTM-G-8LHNSPWCG8:7:event_setup_start:to:event_setup_end | 1.496 s | 1 ms |
| GTM-G-8LHNSPWCG8:7:event_setup_start:to:event_execute_end | 1.496 s | 31 ms |
| GTM-G-8LHNSPWCG8:7:event_evaluation_start:to:event_evaluation_end | 1.497 s | 1 ms |
| GTM-G-8LHNSPWCG8:8:event_setup_start:to:event_setup_end | 1.500 s | 1 ms |
| GTM-G-8LHNSPWCG8:8:event_setup_start:to:event_execute_end | 1.500 s | 29 ms |
| GTM-G-8LHNSPWCG8:8:event_evaluation_start:to:event_evaluation_end | 1.500 s | 1 ms |
| GTM-G-8LHNSPWCG8:9:event_setup_start:to:event_setup_end | 1.501 s | 1 ms |
| GTM-G-8LHNSPWCG8:9:event_setup_start:to:event_execute_end | 1.501 s | 33 ms |
| GTM-G-8LHNSPWCG8:9:event_evaluation_start:to:event_evaluation_end | 1.501 s | 0 ms |
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></p> |
| Render time | 463 ms |
| Load time | 0 ms |
| Size (width*height) | 119340 |
| DOM path | |
| div:eq(1) > main#main > div:eq(1) > div > div > section#64861 > div > div#64872 > div#64881 > p:eq(1)> div:eq(1) > main#main > div:eq(1) > div > div > section#64861 > div > div#64872 > div#64881 > p:eq(1)> | |
0.00058 cumulative layout shift collected from the Cumulative Layout Shift API.
These HTML elements contribute most to the Cumulative Layout Shifts of the page. The higher score, the more layout shift.
| Score | HTML Element |
|---|---|
| 0.00058 | <nav class="secondary-links" aria-label="Secondary Navigation"></nav>,<svg class="icon icon--inline" focusable="false" aria-hidden="true"></svg>,<button class="meganav__list-item-toggle btn-toggle" aria-expanded="false" aria-controls="meganav-learningzone-panel"></button>,<svg class="icon icon--inline" focusable="false" aria-hidden="true"></svg>,<button class="meganav__list-item-toggle btn-toggle" aria-expanded="false" aria-controls="meganav-ourorganisation-panel"></button> |
| body#top-1301 > div:eq(0) > header > div:eq(0) > div > nav,body#top-1301 > div:eq(0) > header > div:eq(1) > nav > div:eq(0) > div > ol > li:eq(0) > p#meganav-supportforbusinesses-trigger > button > svg,body#top-1301 > div:eq(0) > header > div:eq(1) > nav > div:eq(0) > div > ol > li:eq(1) > p#meganav-learningzone-trigger > button,body#top-1301 > div:eq(0) > header > div:eq(1) > nav > div:eq(0) > div > ol > li:eq(1) > p#meganav-learningzone-trigger > button > svg,body#top-1301 > div:eq(0) > header > div:eq(1) > nav > div:eq(0) > div > ol > li:eq(2) > p#meganav-ourorganisation-trigger > button | |

The elements that have shifted place is highlighted in the image (that have a higher value than 0.01). If the element shifted outside of the viewport, you will not see it there. It can be hard to understand what content that has shifted, if that's the case, checkout the video or the filmstrip of the run.
There are no Server Timings.
There are no custom configured scripts.
There are no custom extra metrics from scripting.
| name | value |
|---|---|
| AudioHandlers | 0 |
| Documents | 11 |
| Frames | 8 |
| JSEventListeners | 108 |
| LayoutObjects | 664 |
| MediaKeySessions | 0 |
| MediaKeys | 0 |
| Nodes | 4077 |
| Resources | 28 |
| ContextLifecycleStateObservers | 14 |
| V8PerContextDatas | 1 |
| WorkerGlobalScopes | 0 |
| UACSSResources | 0 |
| RTCPeerConnections | 0 |
| ResourceFetchers | 11 |
| AdSubframes | 0 |
| DetachedScriptStates | 2 |
| ArrayBufferContents | 0 |
| LayoutCount | 13 |
| RecalcStyleCount | 18 |
| LayoutDuration | 63 |
| RecalcStyleDuration | 56 |
| DevToolsCommandDuration | 48 |
| ScriptDuration | 630 |
| V8CompileDuration | 3 |
| TaskDuration | 1490 |
| TaskOtherDuration | 690 |
| ThreadTime | 1 |
| ProcessTime | 1 |
| JSHeapUsedSize | 7646808 |
| JSHeapTotalSize | 10842112 |
| FirstMeaningfulPaint | 1010 |
How the page is built.
| Summary | |
|---|---|
| HTTP version | HTTP/1.1 |
| Total requests | 39 |
| Total domains | 8 |
| Total transfer size | 2.2 MB |
| Total content size | 4.0 MB |
| Responses missing compression | 12 |
| Number of cookies | 1 |
| Third party cookies | 0 |
| Requests per response code | |
|---|---|
| 200 | 37 |
| 204 | 2 |
| Content | Header Size | Transfer Size | Content Size | Requests |
|---|---|---|---|---|
| html | 521 B | 38.7 KB | 194.5 KB | 2 |
| css | 654 B | 62.6 KB | 369.3 KB | 4 |
| javascript | 693 B | 646.2 KB | 1.9 MB | 5 |
| image | 5.9 KB | 1.4 MB | 1.4 MB | 10 |
| font | 0 b | 67.3 KB | 66.6 KB | 2 |
| svg | 5.0 KB | 51.9 KB | 51.9 KB | 9 |
| plain | 537 B | 495 B | 632 B | 1 |
| other | 1005 B | 445 B | 445 B | 3 |
| json | 543 B | 1.7 KB | 1.5 KB | 3 |
| Total | 14.8 KB | 2.2 MB | 4.0 MB | 39 |
| Domain | Total download time | Transfer Size | Content Size | Requests |
|---|---|---|---|---|
| www.scottish-enterprise.com | 2.292 s | 1.8 MB | 2.8 MB | 26 |
| fonts.googleapis.com | 85 ms | 1.1 KB | 14.7 KB | 1 |
| use.typekit.net | 75 ms | 18.1 KB | 18.3 KB | 2 |
| js.monitor.azure.com | 73 ms | 56.5 KB | 120.2 KB | 1 |
| www.googletagmanager.com | 235 ms | 336.0 KB | 1002.2 KB | 4 |
| p.typekit.net | 52 ms | 172 B | 5 B | 1 |
| fonts.gstatic.com | 10 ms | 50.0 KB | 49.5 KB | 1 |
| uksouth-0.in.applicationinsights.azure.com | 131 ms | 286 B | 124 B | 3 |
| type | min | median | max |
|---|---|---|---|
| Expires | 0 seconds | 15 minutes | 1 year |
| Last modified | 0 seconds | 10 weeks | 1 year |
| Content | Transfer Size | Requests |
|---|---|---|
| html | 14 B | 1 |
| css | 0 b | 0 |
| javascript | 222.5 KB | 2 |
| image | 1.5 KB | 1 |
| font | 0 b | 0 |
| other | 445 B | 3 |
| json | 1.7 KB | 3 |
| Total | 226.1 KB | 10 |
Includes requests done after onLoad.
| Content | Transfer Size | Requests |
|---|---|---|
| html | 14 B | 1 |
| css | 0 b | 0 |
| javascript | 222.5 KB | 2 |
| image | 1.5 KB | 1 |
| font | 0 b | 0 |
| other | 445 B | 3 |
| json | 1.7 KB | 3 |
| Total | 226.1 KB | 10 |
Render blocking information directly from Chrome.
| Blocking | In body parser blocking | Potentially blocking |
|---|---|---|
| 4 | 0 | 0 |
| URL | Type |
|---|---|
| https://www.scottish...s/scripts/site.js | non_blocking |
| https://www.googleta...nager.com/gtag/js | non_blocking |
| https://www.googleta...anager.com/gtm.js | non_blocking |
| https://www.googleta.../gtag/destination | non_blocking |
| https://www.scottish...s/styles/site.css | blocking |
| https://js.monitor.a...pts/b/ai.2.min.js | non_blocking |
| https://fonts.gstati...qQ43Rh_fKDp.woff2 | non_blocking |
| https://use.typekit....00007735ea44/30/l | non_blocking |
| https://fonts.google...ogleapis.com/css2 | blocking |
| https://use.typekit.net/edy3lpy.css | blocking |
| https://p.typekit.ne...typekit.net/p.css | blocking |
Third party requests categorised by Third party web.
| Category | Requests |
|---|---|
| cdn | 5 |
| survelliance | 6 |
| tag-manager | 4 |
| Category | Number of tools |
|---|---|
| cdn | 2 |
| survelliance | 2 |
| tag-manager | 1 |
Here's a list of domains that didn't match any tool in Third party web. If you are sure they are third party domains, please do a PR to that project. You can also fine tune the list using --firstParty.
| js.monitor.azure.com |
| uksouth-0.in.applicationinsights.azure.com |
Calculated using .*scottish-enterprise.* (use --firstParty to configure).
| Content | Header Size | Transfer Size | Content Size | Requests |
|---|---|---|---|---|
| html | 521 B | 38.7 KB | 194.5 KB | 1 |
| css | 654 B | 60.5 KB | 353.4 KB | 1 |
| javascript | 693 B | 253.6 KB | 869.3 KB | 1 |
| image | 5.9 KB | 1.4 MB | 1.4 MB | 10 |
| font | 0 b | 0 b | 0 b | 0 |
| svg | 5.0 KB | 51.9 KB | 51.9 KB | 9 |
| plain | 537 B | 495 B | 632 B | 1 |
| json | 543 B | 1.4 KB | 1.3 KB | 1 |
| other | 1005 B | 445 B | 445 B | 2 |
| Total | 14.8 KB | 1.8 MB | 2.8 MB | 26 |
| Content | Header Size | Transfer Size | Content Size | Requests |
|---|---|---|---|---|
| html | 0 b | 14 B | 0 b | 1 |
| css | 0 b | 2.1 KB | 15.9 KB | 3 |
| javascript | 0 b | 392.5 KB | 1.1 MB | 4 |
| image | 0 b | 0 b | 0 b | 0 |
| font | 0 b | 67.3 KB | 66.6 KB | 2 |
| other | 0 b | 0 b | 0 b | 1 |
| json | 0 b | 286 B | 124 B | 2 |
| Total | N/A | 462.3 KB | 1.2 MB | 13 |

afterPageCompleteCheck.png

layoutShift.png

largestContentfulPaint.png