Sliver is a lightweight JavaScript library.
See the sample-apps directory.
Hosted sample-apps/app1
: https://johnkerl.org/sliver/sample-apps/app1
Used by the jsbee
app: https://johnkerl.org/jsbee
JavaScript frameworks such as React are full-featured, rich, and powerful. And I wouldn't think of doing complex web development without one of them.
On the other hand, for simple projects, I find such frameworks to be too much. As I write this (2024), the underlying browser model is mature and well-documented, as are ES6, HTML, and CSS. You can do a lot of things with only these. Moreover, they're single and they're stable. Single in the sense there one standard for ES6, for HTML, for CSS; stable in the sense that changes happen by committee, and are phased over years.
By contrast, JavaScript frameworks are multiple and ever-changing. Multiple in the sense that knowing React deeply may offer only general help in learning Angular or Vue.js, and vice versa: these frameworks solve similar problems, but in different ways. Ever-changing in the sense that a new framework version may require app-level changes.
As well, JavaScript frameworks are often complete and opaque in the sense that they successfully hide much or all of the browser API. When I was doing full-time React development in the 2018-2020 timeframe, while I got quite comfortable with React, I later realized I didn't know much at all about how to do web development without React. This is a separate learning.
Last is packaging: while npm
and yarn
are powerful tools, for simple use-cases it suffices to point at a URL with a .js
file in it.
Given those concerns, for small-scale web development, one might simply use no framework at all, sticking with HTML, CSS, and ES6. An examples of this is pangram-checker.
But sometimes one wants some application state, some encapsulation, some component reuse. For jsbee I wanted some reusable classes between my application and the browser API --- a mere thin sliver of logic, decorating the browser API rather than hiding it. Thus Sliver was born.
This was just a fun little holiday lark at the end of 2024.
- Allow more CSS props in widgets, e.g. button colors
- More assertions
dev
:- Run
npx http-server ~/pub_http_internet -o -p 9999 &
on the laptop - Use apps which do
import { ... } from "http://127.0.1:9999/sliver/dev/sliver.js"
- Edit
dev/sliver.js
and any appdev.html
- Test
http://127.0.1:9999/path/to/that/app/dev.html
- Run
staging
:- Apply diffs from
dev/sliver.js
tostaging/sliver.js
- Apply diffs from app
dev.html
to appstaging.html
- Push to ISP
- Test with
https://johnkerl.org/path/to/that/app/staging.html
- Apply diffs from
- Production:
- Apply diffs from
staging/sliver.js
tostable/sliver.js
- Apply diffs from app
staging.html
to appindex.html
- Push to ISP
- Test with
https://johnkerl.org/path/to/that/app/index.html
- Apply diffs from