Go to file
Zach Leatherman e8f8a543de Update link
2024-10-01 16:25:05 -05:00
_config Update JS front matter name, use cross-env where available, adds build-nocolor script 2024-07-16 09:38:01 -05:00
_data Drastically simplify the drafts workflow 2024-09-24 12:18:16 -05:00
_includes Upgrade a few deps, move a few things around. Remove the dual feeds (JSON still supported) 2024-10-01 15:42:41 -05:00
.github/workflows A few more GitHub pages tweaks 2024-03-07 08:52:42 -06:00
content Upgrade a few deps, move a few things around. Remove the dual feeds (JSON still supported) 2024-10-01 15:42:41 -05:00
public Adds barebones View Transition API 2024-09-05 16:07:41 -05:00
.editorconfig Convert to tabs 2023-01-23 11:37:44 -06:00
.gitignore Add cache to gitignore 2024-02-12 09:16:51 -06:00
.nojekyll Fixes https://github.com/11ty/eleventy-base-blog/issues/87 2022-06-29 14:28:21 -05:00
.nvmrc Update Node version! 2024-08-03 19:56:43 -05:00
eleventy.config.js Change navigation order 2024-10-01 15:54:03 -05:00
LICENSE Tiny tweaks 2023-01-23 11:37:54 -06:00
netlify.toml Remove Netlify plugins 2024-09-11 16:15:15 -05:00
package.json Upgrade a few deps, move a few things around. Remove the dual feeds (JSON still supported) 2024-10-01 15:42:41 -05:00
README.md Update link 2024-10-01 16:25:05 -05:00
vercel.json Always use trailingSlash: true on Vercel 2024-09-27 17:04:09 -05:00

eleventy-base-blog v9

A starter repository showing how to build a blog with the Eleventy site generator (using the v3.0 release).

Getting Started

  1. Make a directory and navigate to it:
mkdir my-blog-name
cd my-blog-name
  1. Clone this Repository
git clone https://github.com/11ty/eleventy-base-blog.git .

Optional: Review eleventy.config.js and _data/metadata.js to configure the sites options and data.

  1. Install dependencies
npm install
  1. Run Eleventy

Generate a production-ready build to the _site folder:

npx @11ty/eleventy

Or build and host on a local development server:

npx @11ty/eleventy --serve

Or you can run debug mode to see all the internals.

Features

  • Using Eleventy v3 with zero-JavaScript output.
  • Performance focused: four-hundos Lighthouse score out of the box!
    • 0 Cumulative Layout Shift
    • 0ms Total Blocking Time
  • Local development live reload provided by Eleventy Dev Server.
  • Content-driven navigation menu
  • Fully automated Image optimization
    • Zero-JavaScript output.
    • Support for modern image formats automatically (e.g. AVIF and WebP)
    • Processes images on-request during --serve for speedy local builds.
    • Prefers <img> markup if possible (single image format) but switches automatically to <picture> for multiple image formats.
    • Automated <picture> syntax markup with srcset and optional sizes
    • Includes width/height attributes to avoid content layout shift.
    • Includes loading="lazy" for native lazy loading without JavaScript.
    • Includes decoding="async"
    • Images can be co-located with blog post files.
  • Per page CSS bundles via eleventy-plugin-bundle.
  • Built-in syntax highlighter (zero-JavaScript output).
  • Draft content: use draft: true to mark any template as a draft. Drafts are only included during --serve/--watch and are excluded from full builds. This is driven by the addPreprocessor configuration API in eleventy.config.js. Schema validator will show an error if non-boolean value is set in data cascade.
  • Blog Posts
    • Automated next/previous links
    • Accessible deep links to headings
  • Generated Pages

Demos

Deploy this to your own site

Deploy this Eleventy site in just a few clicks on these services:

Implementation Notes

  • content/about/index.md is an example of a content page.
  • content/blog/ has the blog posts but really they can live in any directory. They need only the posts tag to be included in the blog posts collection.
  • Use the eleventyNavigation key (via the Eleventy Navigation plugin) in your front matter to add a template to the top level site navigation. This is in use on content/index.njk and content/about/index.md.
  • Content can be in any template format (blog posts neednt exclusively be markdown, for example). Configure your projects supported templates in eleventy.config.js -> templateFormats.
  • The public folder in your input directory will be copied to the output folder (via addPassthroughCopy in the eleventy.config.js file). This means ./public/css/* will live at ./_site/css/* after your build completes.
  • This project uses three Eleventy Layouts:
    • _includes/layouts/base.njk: the top level HTML structure
    • _includes/layouts/home.njk: the home page template (wrapped into base.njk)
    • _includes/layouts/post.njk: the blog post template (wrapped into base.njk)
  • _includes/postslist.njk is a Nunjucks include and is a reusable component used to display a list of all the posts. content/index.njk has an example of how to use it.

Content Security Policy

If your site enforces a Content Security Policy (as public-facing sites should), you have a few choices (pick one):

  1. In base.njk, remove <style>{% getBundle "css" %}</style> and uncomment <link rel="stylesheet" href="{% getBundleFileUrl "css" %}">
  2. Configure the server with the CSP directive style-src: 'unsafe-inline' (less secure).