Skip to content

Latest commit

 

History

History
44 lines (27 loc) · 2.01 KB

README.md

File metadata and controls

44 lines (27 loc) · 2.01 KB

Slim SSR

An implementation of a server-side rendering (SSR) web framework written in 37 lines of code.

An in-depth write-up on this SSR implementation can be found here.

Features include:

  • Ship zero JavaScript by default
  • Expressive markup and styling using tagged templates
  • Island-based architecture via web components
  • No build step
  • Zero configuration

This implementation is based on the research, experimentation, and takeaways from work on Delgada –– a web framework for building slim multipage websites.

The point of this is not to provide a feature complete implementation of SSR by 2022 standards, but to show that one can get shockingly far with very little code by building on top of the web standards and conventions available today. Think of it as a celebration of the modern web and what it enables.

Usage

To test out the demo app, clone this repo locally and run the following commands.

# Install slim-ssr dependencies
cd slim-ssr && npm install && cd ..

# Install demo dependencies
cd demo && npm install

# Start demo server
npm start

A note on developer experience

For a drastically improved developer experience, install the lit-html and es6-string-html VS Code extensions.

They make a world of difference while writing component markup/styles in tagged templates. They can be used to add a ton of helpful features like syntax highlighting, quick hover info, HTML tag folding, and so on.

Emmet support can also be enabled in tagged templates by changing the "Emmet: Include Languages" setting in VS Code. I recommend adding mappings for "javascript": "html" and "typescript": "html".

License

This is licensed under MIT. Feel free to use, remix, and adapt the code found in this repo in your projects.