GitXplorerGitXplorer
g

11ty-example

public
0 stars
0 forks
3 issues

Commits

List of commits on branch main.
Unverified
92d1f674d410d377600ada00072942c5ad6bc586

Added input set .harness/Build_gtsiolis_11ty_example_1723799460616-push-trigger-input-set-1723799463456.yaml

ggtsiolis committed 5 months ago
Unverified
09836bdf9586d5314bbeb2d0a881bf5f275bcd90

Added input set .harness/Build_gtsiolis_11ty_example_1723799460616-pr-trigger-input-set-1723799461857.yaml

ggtsiolis committed 5 months ago
Unverified
c42942c6c9b7aab645afc57f8a12d8f0a3ea63e6

Added pipeline .harness/pipelines/11ty-example-1723799456663.yaml

ggtsiolis committed 5 months ago
Verified
97a1db27c169d7cc81fd1a77d98b1dcf0388f893

Create devcontainer.json

ggtsiolis committed 2 years ago
Verified
add21c71276f0fbef9ff6338bf8641c81640a027

Update README.md

ggtsiolis committed 3 years ago
Verified
76269a878395cb205b1bd31b9cc6a91d615011fa

Create README.md

ggtsiolis committed 3 years ago

README

The README file for this repository.

eleventy-high-performance-blog

A starter repository for building a blog with the Eleventy static site generator implementing a wide range of performance best practices.

Screenshot showing that the site achieves 100 points on Lighthouse by default

Based on the awesome eleventy-base-blog.

// TEST

Demo

Getting Started

1. Generate a new repository from this repository template

Click the "Use this template" button. Alternatively you can clone this repo yourself and push your copy to your favorite git repository.

2. Clone your new repository

git clone https://github.com/YOUR_REPO

3. Navigate to the directory

cd my-blog-name

4. Install dependencies

npm install

5. Build, serve, watch and test

npm run watch

6. Build and test

npm run build

Customize

  • Search for "Update me" across files in your editor to find all the site specific things you should update.
  • Update the favicons in 'img/favicon/'.
  • If you don't want the (same-origin) Google Analytics integration, rip it out 😛.
  • Otherwise: Knock yourself out. This is a template repository.
  • For a simple color override, adjust these CSS variables at the top of css/main.css.
:root {
  --primary: #E7BF60;
  --primary-dark: #f9c412;
}

Features

Performance outcomes

Performance optimizations

Images

  • Generates multiple sizes of each image and uses them in srcset.
  • Generates a blurry placeholder for each image (without adding an HTML element or using JS).
  • Transcodes images to AVIF (currently off-by-default due to instabillity of the encoder) and webp and generates picture element.
  • Lazy loads images (using native loading=lazy).
  • Async decodes images (using decoding=async).
  • Avoids CLS impact of images by inferring and providing width and height (Supported in Chrome, Firefox and Safari 14+).
  • Downloads remote images and stores/serves them locally.
  • Immutable URLs.

CSS

  • Defaults to the compact "classless" Bahunya CSS framework.
  • Inlines CSS.
  • Dead-code-eliminates / tree-shakes / purges (pick your favorite word) unused CSS on a per-page basis with PurgeCSS.
  • Minified CSS with csso.

Miscellaneous

  • Immutable URLs for JS.
  • Sets immutable caching headers for images, fonts, and JS (CSS is inlined). Currently implements for Netflify _headers file.
  • Minifies HTML and optimizes it for compression. Uses html-minifier with aggressive options.
  • Uses rollup to bundle JS and minifies it with terser.
  • Prefetches same-origin navigations when a navigation is likely.
  • If an AMP files is present, optimizes it.

Fonts

  • Serves fonts from same origin.
  • Makes fonts display:swap.

Analytics

  • Supports locally serving Google Analytics's JS and proxying it's hit requests to a Netlify proxy (other proxies could be easily added).
  • Support for noscript hit requests.
  • Avoids blocking onload on analytics requests.

DX features

  • Uses 🚨 as favicon during local development.
  • Supports a range of default tests.
  • Runs build and tests on git push.
  • Sourcemap generated for JS.

SEO & Social

  • Share button prefering navigator.share() and falling back to Twitter. Using OS-like share-icon.
  • Support for OGP metadata.
  • Support for Twitter metadata.
  • Support for schema.org JSON-LD.
  • Sitemap.xml generation.

Largely useless glitter

  • Read time estimate.
  • Animated scroll progress bar…
  • …with an optimized implementation that should never cause a layout.

Security

Generates a strong CSP for the base template.

  • Default-src is self.
  • Disallows plugins.
  • Generates hash based CSP for the JS used on the site.

Build performance

  • Downloaded remote images, and generated sizes are cached in the local filesystem…
  • …and SHOULD be committed to git.
  • .persistimages.sh helps with this.

Disclaimer

This is not an officially supported Google product, but rather Malte's private best-effort open-source project.