JMPerez Blog

https://jmperezperez.com/
Web development, performance, and some other good practices
Added 5 months ago, Updated 20 minutes ago

LIGHTHOUSE 82

Lighthouse version2.5.0
Progressive Web App82
Registers a service workertrue
Responds with a 200 when offlinetrue
Contains some content when JavaScript is not availabletrue
Uses HTTPStrue
Redirects HTTP traffic to HTTPStrue
Page load is fast enough on 3Gtrue
User will not be prompted to Install the Web Appfalse
Is not configured for a custom splash screenfalse
Address bar matches brand colorstrue
Has a `<meta name="viewport">` tag with `width` or `initial-scale`true
Content is sized correctly for the viewporttrue
Site works cross-browserfalse
Page transitions don't feel like they block on the networkfalse
Each page has a URLfalse
Performance99
First meaningful paint100
First Interactive (beta)98
Consistently Interactive (beta)98
Perceptual Speed Index95
Estimated Input Latency100
Reduce render-blocking stylesheets100
Reduce render-blocking scripts100
Properly size images90
Offscreen images0
Optimize images100
Serve images as WebP100
Enable text compression100
Keep server response times low (TTFB)true
Avoids enormous network payloads100
Avoids an excessive DOM size100
Critical Request Chainstrue
User Timing marks and measurestrue
Screenshot Thumbnails100
Accessibility89
`[accesskey]` values are unique.true
`[aria-*]` attributes match their roles.true
`[role]`s have all required `[aria-*]` attributes.true
Elements with `[role]` that require specific children `[role]`s, are present.true
`[role]`s are contained by their required parent element.true
`[role]` values are valid.true
`[aria-*]` attributes do not have valid values.false
`[aria-*]` attributes are valid and not misspelled.true
`<audio>` elements contain a `<track>` element with `[kind="captions"]`.true
Buttons have an accessible name.true
The page contains a heading, skip link, or landmark region.true
Background and foreground colors do not have a sufficient contrast ratio.false
`<dl>`'s contain only properly-ordered `<dt>` and `<dd>` groups, `<script>` or `<template>` elements.true
Definition list items are wrapped in `<dl>` elements.true
Document has a `<title>` element.true
`[id]` attributes on the page are unique.true
`<frame>` or `<iframe>` elements have a title.true
`<html>` element has a `[lang]` attribute.true
`<html>` element has a valid value for its `[lang]` attribute.true
Image elements do not have `[alt]` attributes.false
`<input type="image">` elements have `[alt]` text.true
Form elements have associated labels.true
Presentational `<table>` elements avoid using `<th>`, `<caption>` or the `[summary]` attribute.true
Links have a discernible name.true
Lists contain only `<li>` elements and script supporting elements (`<script>` and `<template>`).true
List items (`<li>`) are contained within `<ul>` or `<ol>` parent elements.true
The document does not use `<meta http-equiv="refresh">`.true
`[user-scalable="no"]` is used in the `<meta name="viewport">` element or the `[maximum-scale]` attribute is less than 5.false
`<object>` elements have `[alt]` text.true
No element has a `[tabindex]` value greater than 0.true
Cells in a `<table>` element that use the `[headers]` attribute only refer to other cells of that same table.true
`<th>` elements and elements with `[role="columnheader"/"rowheader"]` have data cells they describe.true
`[lang]` attributes have a valid value.true
`<video>` elements contain a `<track>` element with `[kind="captions"]`.true
`<video>` elements contain a `<track>` element with `[kind="description"]`.true
Best Practices94
Avoids Application Cachetrue
Avoids WebSQL DBtrue
Uses HTTPStrue
Uses HTTP/2 for its own resourcestrue
Uses passive listeners to improve scrolling performancetrue
Avoids Mutation Events in its own scriptstrue
Avoids `document.write()`true
Opens external anchors using `rel="noopener"`true
Avoids requesting the geolocation permission on page loadtrue
Avoids front-end JavaScript libraries with known security vulnerabilitiestrue
Avoids requesting the notification permission on page loadtrue
Avoids deprecated APIstrue
Manifest's `short_name` won't be truncated when displayed on homescreentrue
Allows users to paste into password fieldstrue
No browser errors logged to the consoletrue
Does not uses Images with appropriate aspect ratio0

WebPageTest

PageSpeed Insights

MANIFEST

{
  "lang": "en",
  "short_name": "JMPerez",
  "name": "JMPerez Blog",
  "description": "Web development, performance, and some other good practices",
  "start_url": "/",
  "display": "browser",
  "background_color": "#f9f9f9",
  "theme_color": "#005689",
  "icons": [
    {
      "src": "/assets/icons/192.png",
      "sizes": "192x192",
      "type": "image/png"
    },
    {
      "src": "/assets/icons/144.png",
      "sizes": "144x144",
      "type": "image/png"
    }
  ]
}