Joel Hanson | Portfolio

https://joelhanson.ml/index.html
my portfolio
Added 5 months ago, Updated 20 minutes ago

LIGHTHOUSE 100

Lighthouse version2.5.0
Progressive Web App100
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 can be prompted to Install the Web Apptrue
Configured for a custom splash screentrue
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
Performance62
First meaningful paint38
First Interactive (beta)71
Consistently Interactive (beta)71
Perceptual Speed Index58
Estimated Input Latency100
Reduce render-blocking stylesheets0
Reduce render-blocking scripts100
Properly size imagesnull
Offscreen imagesnull
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 Chainsfalse
User Timing marks and measurestrue
Screenshot Thumbnails100
Accessibility100
`[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 have valid values.true
`[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 have a sufficient contrast ratio.true
`<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 have `[alt]` attributes.true
`<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 not used in the `<meta name="viewport">` element and the `[maximum-scale]` attribute is not less than 5.true
`<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 Practices81
Avoids Application Cachetrue
Avoids WebSQL DBtrue
Uses HTTPStrue
Uses HTTP/2 for its own resourcestrue
Does not use passive listeners to improve scrolling performancefalse
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
Uses deprecated API'sfalse
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 rationull

WebPageTest

PageSpeed Insights

MANIFEST

{
  "name": "Joel Hanson | Portfolio",
  "short_name": "Joel",
  "description": "my portfolio",
  "icons": [
    {
      "src": "image/joel1.webp",
      "type": "image/webp",
      "sizes": "48x48"
    },
    {
      "src": "image/joel1.webp",
      "type": "image/webp",
      "sizes": "96x96"
    },
    {
      "src": "image/joel1.webp",
      "type": "image/webp",
      "sizes": "1080x1080"
    },
    {
      "src": "image/joel1.webp",
      "type": "image/webp",
      "sizes": "192x192"
    }
  ],
  "start_url": "/index.html",
  "display": "standalone",
  "background_color": "#f44336",
  "theme_color": "#f44336",
  "gcm_sender_id": "103953800507"
}