Oat – Ultra-lightweight, zero dependency, semantic HTML, CSS, JS UI library
539 points
1 month ago
| 50 comments
| oat.ink
| HN
https://github.com/knadh/oat

Related: https://nadh.in/blog/javascript-ecosystem-software-developme...

jamamp
1 month ago
[-]
I think it's valiant to try to do all of this with semantic HTML elements to achieve the right effects, and try to go for a "classless CSS" paradigm to get a nice looking and functional web app (as a fan of classless CSS myself). But scrolling through the component catalog, it unfortunately feels like it's all over the place and inconsistent with semantic vs basic elements, data tags vs aria attributes, and sprinkling some css classes over some of it.

I do very much like that by introducing aria attributes, the CSS reacts to it and styles it appropriately. As opposed to a full-blown react component library which does all of that for you. It would be a good exercise for developers to think aria-first and let the library just help with styling.

Lastly, I think the best part is that this component library has a native sidebar. So many of these I see and they have a nice web page which showcases all the components and I want to replicate their layout and nav/sidebars but they only focus on smaller re-usable components and not the layout. So that's a nice touch, I think. And, as someone who keeps an eye on but doesn't do a lot of frontend, the fact that a sidebar is an aside > nav > ul next to a main just makes so much sense and doesn't have a lot of cruft around it.

reply
skeledrew
1 month ago
[-]
This site got me going. Almost had whiplash when I tapped a link and the page loaded literally instantly. I've almost forgotten that that's possible on the internet. I'm not a web dev, but I'm inspired to get into it now because of this site.
reply
thedumbname
1 month ago
[-]
Try uBlock Origin and most of your sites will load instantly (hint: most of the time it is third-party analytics/ads issue)
reply
skeledrew
1 month ago
[-]
I have many blockers. Doesn't help performance at all IMO.
reply
darkvertex
1 month ago
[-]
You should try making a site with Astro. Load speed is cray cray.
reply
allthetime
1 month ago
[-]
Yeah I’m a recent Astro convert. To be fair, any static site will have this effect. It’s just everyone is using react to make landing pages now.
reply
ethmarks
1 month ago
[-]
What makes Astro fast isn't just that it's static, it's that it automatically pre-renders and it doesn't ship a runtime. React can render to static as well, it just also ships the React runtime.
reply
robertoandred
1 month ago
[-]
React sites are easily static.
reply
mbreese
1 month ago
[-]
Static or pre-rendered static? I rarely come across the latter, but the former is pretty common.
reply
1718627440
1 month ago
[-]
I mean you also have HN as a reference.
reply
skeledrew
1 month ago
[-]
I use an app for HN, and try to wherever I can due to my general experience with web things, so it's a different feel. But also HN being snappy is pretty much an upfront expectation given it's like 99.99% text.
reply
1718627440
1 month ago
[-]
TIL there is an HN app.
reply
skeledrew
1 month ago
[-]
Yep, several. I've found Hacki best for me so far, but actually I'm considering to make my own as there are a few pain points and extras I'd like handled, and it'd be a nice learning experience.

https://f-droid.org/packages/com.jiaqifeng.hacki

reply
swiftcoder
1 month ago
[-]
The motivating blog post[1] linked from the front page is probably going to generate a more interesting discussion than the framework itself.

As someone who has to deal with both angular and nextjs for different (but overlapping) stacks at work, I find myself increasingly sympathetic to this viewpoint.

[1]: https://nadh.in/blog/javascript-ecosystem-software-developme...

reply
e12e
1 month ago
[-]
Nice link - still relevant IMNHO - even though it's from 2021.

Discussed at the time:

https://news.ycombinator.com/item?id=28892933

reply
latchkey
1 month ago
[-]
It has updates at the bottom. Most recently 14 Sep 2025.
reply
skeledrew
1 month ago
[-]
This website pleases me greatly. 0 time from tap to fully loaded pages.
reply
xyzzy_plugh
1 month ago
[-]
reply
swiftcoder
1 month ago
[-]
Ah ha, figured it must have been discussed here before!
reply
JSR_FDED
1 month ago
[-]
This has the simplicity I thought I was going to get from DaisyUI but didn’t. Pairing this with Datastar seems like a super powerful combination that leans on actual web standards, not “ecosystems”.
reply
potato-peeler
1 month ago
[-]
Thank you testing this on older browsers before releasing. This is truly an ultra minimal library - https://ibb.co/DDGmLYdg, https://ibb.co/h1WQG3GK
reply
appplication
1 month ago
[-]
Genuine question, do you normally use old browsers as your daily driver for interfacing with the web? I’d be interested in learning why.
reply
potato-peeler
1 month ago
[-]
Not as a daily driver but to make sure a software has wide support, not all users update their phone frequently. Also, many web features do not require using the latest in browser features.

And just to be clear, I was poking fun at this so called “CTO”. That guy should have known better.

I see many web/ui frameworks posted in HN which don’t test in older browsers but still claim to be minimal or plain.

reply
recursive
1 month ago
[-]
Presumably it's relevant not because they use old browsers but because some of their software's users do. And I doubt most of them have a reason for doing so.
reply
appplication
1 month ago
[-]
That makes sense. As a solo dev for my side projects, I’ve intentionally decided to not support legacy browsers, which I understand bugs some folks (weirdly, usually the super tech minded types you find in here) but I’m just one guy and I have a hard time seeing the value in these user segments being worth the squeeze.
reply
hiyer
1 month ago
[-]
Reminds me of what bootstrap [1] was like around a decade ago. It's gotten quite a bit bloated since then though.

1. https://getbootstrap.com/

reply
hkt
1 month ago
[-]
This is gorgeous. I hate frontend because of its sheer gratuity, and this is the kind of thing that might get me back into it. The only other contender for interactivity I'd consider is HTMX, and I'm going to boldly assume I'll be able to combine them without too much bother.

Bravo to the author, keep at it. I'll be recommending this to anyone who will listen.

reply
culi
1 month ago
[-]
<aside> is not the correct semantic element for sidebars. The purpose of <aside> is for content that is indirectly related to the "main" content of the page. Sometimes a sidebar fits that definition but not always
reply
roxolotl
1 month ago
[-]
There’s a ton of semantic drop in css libraries similar to this. Love seeing new ones. Quality varies wildly but this site shows 50+ drop in stylesheets for those writing semantic html: https://dohliam.github.io/dropin-minimal-css/
reply
layer8
1 month ago
[-]
I had to read your comment three times before figuring out that you mean “drop-in”. Sometimes hyphens do matter! :)
reply
neya
1 month ago
[-]
This isn't upvoted enough. This is more interesting than the OP's project! Thanks for sharing!
reply
sgc
1 month ago
[-]
I love it. You can use the right arrow to cycle through them.
reply
heyyeah
1 month ago
[-]
do you have any recommendations from the list?
reply
roxolotl
1 month ago
[-]
Here’s some that seem genuinely useful to me depending on what you’re looking for.

- https://concrete.style/

- water.css https://watercss.kognise.dev/

- magick.css https://css.winterveil.net/

- mui.css: https://www.muicss.com/

- pico.css: https://picocss.com/

reply
nkmnz
1 month ago
[-]
I know that guy from listmonk! I always thought the frontend could use some love and planned to spend a couple of days on contributing a couple of ideas, but I never came around. Now I know why things are as they are :)
reply
synergy20
1 month ago
[-]
https://github.com/fosiao/rclone-webui-oat seems replacing the heavy duty unmaintained react version at https://github.com/rclone/rclone-webui-react
reply
anton-107
1 month ago
[-]
Why do all the UI component libraries always feature an accordion (something i can build myself in 5 minutes and very rarely need), but always omit a date picker / calendar component (something that is needed almost in every corporate web form and really requires a lot of effort to build)?
reply
anton-107
1 month ago
[-]
I must appoligize - it is there, hidden under "Form elements" in the left menu. Kudos to the authors!
reply
speedgoose
1 month ago
[-]
Isn't it the one from the web browser? An <input type="datetime-local" />

https://developer.mozilla.org/en-US/docs/Web/HTML/Reference/...

reply
webstrand
1 month ago
[-]
That one is highly inconsistent, on some platforms its useless. For instance on Chrome/linux entering historic dates via the datepicker takes minutes to slowly scroll through the years. Always build your own datepicker, you know better what UX pattern will best suit your application and your users.
reply
rohitpaulk
1 month ago
[-]
Surprised that none of the comments here are comparing this to Bootstrap.
reply
weiliddat
1 month ago
[-]
Yeah reminds me of early Bootstrap
reply
JCattheATM
1 month ago
[-]
Wouldn't a comparison to Bulma be more apt?
reply
kitd
1 month ago
[-]
Great work! PicoCSS feels a bit too minimalist at times. This looks like a better balance of lightweight and functional.
reply
gaigalas
1 month ago
[-]
The form component:

https://oat.ink/components/#form

Looks a lot like a raw HTML+CSS framework I made in 2009:

https://alganet.github.io/ghiaweb/ (it has some small glitches, browser widgets changed a lot since 2009).

Particularly the use of the label, fieldset and legend elements as native accessible solutions instead of instrumenting divs. Even the styling and the example resembles it a bit!

https://oat.ink/components/#grid

This is where it falls from grace IMHO. Grid classes are fundamentally non-semantic. I know they're popular and useful, but there must be a better (semantic) way of doing this. I haven't found it yet, but there must be.

reply
Nelkins
1 month ago
[-]
Don't know about anyone else, but the first thing I do with these types of libraries to check out the Accordion component and see if it slides out with a nice animation. This has become my litmus test for how well designed a component library is.
reply
jlg23
1 month ago
[-]
My initial reaction was that I have to use this just because of the buzzword density in the title. But after reading up, it looks like the author was pretty successful in moving the bloat from code to announcement title. I'll give this a try!
reply
eddd-ddde
1 month ago
[-]
The "preview" and "code" buttons in the components break the "alt+arrow" bindings to go back to the previous page. Instead it just alternates between "preview" and "code".
reply
superkuh
1 month ago
[-]
No, this is "Oat - Ultra-lightweight, semantic, zero-dependency Javascript UI component library". If it doesn't work without javascript it is not an HTML UI component library.
reply
recursive
1 month ago
[-]
If it doesn't work without HTML, it's not a JS library.
reply
mega-tux
1 month ago
[-]
I like it. Currently I'm using BeerCSS and I'm pretty satisfied with it. This library is smaller. Any other selling aspect vs BeerCSS? Thanks!
reply
mkl
1 month ago
[-]
Seems pretty unresponsive to me. I'm getting at least half a second of delay before the accordion, drop-down, or switch do anything. Chrome on Windows.
reply
skeledrew
1 month ago
[-]
I have 0 delay for all parts of it. Everything loads and works instantaneously. Firefox on Android.
reply
recursive
1 month ago
[-]
My first guess is that one of your add-ons is interacting badly.
reply
temporallobe
1 month ago
[-]
This is of special interest to me, because man do I hate UI frameworks with tons of external dependencies. Looking at you, Bootstrap.
reply
mxuribe
1 month ago
[-]
I used to think bootstrap was bloated too...and then i had heard - now, i don't know if its true - that bootstrap was originally intended *ONLY* as an internal prototype building tool, and any bloat did not matter...because expected audience, usage would be totally fine for a bloated framework...When i heard, i gave boostrap more of a pass...but, then again, i stopped using it, and began using other, lighter weight frameworks...and nowadays, i so rarely touch any web stuff...and when i do its only for me so then use zero frameworks, and merely display whatever default the browser shows with zero CSS, javascript...then again, my private web page needs are so basic anyway.
reply
temporallobe
1 month ago
[-]
The problem with Bootstrap is that it depends on jQuery and Popper, and its CSS has global classes. It’s perfectly fine if BS is the only UI framework, but if you need to bring to bring in other frameworks or libraries (by choice or by force), then there’s a chance you’ll run into conflicts.
reply
istillwritecode
1 month ago
[-]
bootstrap has not depended on jquery for a long time now.
reply
temporallobe
1 month ago
[-]
Unless you’re stuck on an older version. Also there is a jQuery resolver still embedded even in the latest version that looks for jQuery and tries to use it if it’s globally defined. Caused some nasty bugs in certain Enterprise applications and I have had to manually gut this from the official release.
reply
wsaryoo
1 month ago
[-]
reply
wsaryoo
1 month ago
[-]
Focusing on using it for admin application or data density site
reply
jitbit
1 month ago
[-]
I tried doing something like that in my app, and quickly discovered that some modern semantic/functional tags are STILL not supported in some browsers. Or work badly.

For example, in Safari showModal for a dialog tag causes recalculating layout for EVERY element on a page, it’s up to 59x slower than chromium…. :(

But I love the idea

reply
mrbluecoat
1 month ago
[-]
Nice solution. Reminds me of https://semantic-ui.com/ and https://fomantic-ui.com/
reply
masklinn
1 month ago
[-]
It’s a bit odd that the accordion uses details but the dropdowns require a custom element.
reply
vpribish
1 month ago
[-]
how do you contrast this with https://picocss.com/ ?

I like your presentation of the components, but i'm having trouble finding the essential distinctions

reply
leejoramo
1 month ago
[-]
I often use Pico CSS, and a comparison would be nice.
reply
gormen
1 month ago
[-]
The appeal of libraries like this is not minimalism for its own sake, but the reduction of long‑term operational risk.
reply
saila
1 month ago
[-]
Looks neat. Assuming the site is built using the framework, I ran a couple of the component pages (e.g., accordion) through Lighthouse and there are a number of accessibility issues. Just a heads up.
reply
elseleigh
1 month ago
[-]
This is a very nice library. At a first reading it seems complete (but did I see summary/detail - I don't remember). Bookmarked for further investigation. Congratulations and thank you.
reply
bpev
1 month ago
[-]
Amazing! I recently started building something similar for the same reasons, but more out of frustration rather than out of desire. I'll have to give this one a try and see if it fills the need.
reply
mixmastamyk
1 month ago
[-]
Looks good and like the lightweight aspect. As always, what do I have to do get tabs that look like tabs? What do people have against tabs that look like tabs, instead of buttons?
reply
neon_me
1 month ago
[-]
Nice job! Clicked tru my obscure mobile firefox and all worked well!
reply
Xeoncross
1 month ago
[-]
Thank you for sharing, I would like to see a navigation/menu component added though as that's required for most websites.
reply
bitbasher
1 month ago
[-]
Confusing name, conflicts with Oat++?

https://oatpp.io/

reply
scandox
1 month ago
[-]
Was looking at the spinner component for a few seconds thinking "that's a bit slow"...
reply
Maxion
1 month ago
[-]
This looks very very cool. Will definitely look in to using this for more static internal tools!
reply
TrevorFSmith
1 month ago
[-]
If nothing else, it's refreshing to see nicely modern CSS and JS formatted and laid out in a legible manner. https://github.com/knadh/oat/tree/master/src
reply
intrasight
1 month ago
[-]
What's with variable names starting with "#" as first character?
reply
afishhh
1 month ago
[-]
If you are referring to class members in the JavaScript then those are private fields[1]

[1] https://developer.mozilla.org/en-US/docs/Web/JavaScript/Refe...

reply
intrasight
1 month ago
[-]
I had Googled my question too. Got no hits which is why I asked. Haven't seen it before.
reply
animal_spirits
1 month ago
[-]
That's just markdown headers. Some people like to include # as part of the header aesthetic
reply
chrisweekly
1 month ago
[-]
No, the Q was about javascript not markdown. Peer comment from afishh (9m after yours) has it right.
reply
andrei_says_
1 month ago
[-]
Thank you for this, can’t wait to use. Minimalism at its best.
reply
mgaunard
1 month ago
[-]
The code example doesn't render for me.
reply
freeopinion
1 month ago
[-]
Ditto, if you mean the codeblock in the Typography section.

edit: clarification, focus

reply
freeopinion
1 month ago
[-]
The Preview of the Sidebar doesn't display the Logout button in the footer of the sidebar.

edit: That is, the footer is not within a visible area of the sidebar.

reply
scirob
1 month ago
[-]
ultra-lightweight, these dev's probably go hiking. I like : )
reply
dankobgd
1 month ago
[-]
People need to stop with these stupid 12 column grids and learn how grid and flex work. Other elements are ok but this is just stupid
reply
pphysch
1 month ago
[-]
It's a 12 column grid system built with CSS Grid. 12 column grids are a common design pattern. What would you propose instead?
reply
yoz-y
1 month ago
[-]
Claims no classes but uses data- attributes and also classes (just look at the button example…)

Looks okay, but I don’t see why to use this over something like Marx if all you need is to not have bare browser default styling.

reply
kitd
1 month ago
[-]
The claim is "no classes for native elements". Ie you don't need classes just to create a button etc.
reply
mcknz
1 month ago
[-]
should call it oatmilk for max exposure
reply
scandinavian
1 month ago
[-]
5 day old repo, 2000 stars on GitHub, 400 total weekly downloads on npm. Frontpage of hacker news with a bunch of weird comments. Moderation has been lacking recently.
reply
codegeek
1 month ago
[-]
You are jumping to conclusions. The author is the CTO of the largest online brokerage in India but more importantly, they have created many open source software of good quality. His website and blog are of great quality. Whether you think this library deserves more attention or not is your personal preference but it is far from spam. I havr no affiliation with them but like their work.
reply
bityard
1 month ago
[-]
It's possible for both things to be true: this project is written by a developer well-known within India, AND this thread has a lot of bot (bought?) comments of praise in it.
reply
ssiddharth
1 month ago
[-]
The author is the CTO of Zerodha, India’s largest online brokerage. Not that it matters, just an observation.
reply
smarx007
1 month ago
[-]
I thought they also OSSed a pretty solid https://github.com/frappe/helpdesk helpdesk but that was from Frappe, not Zerodha.
reply
isodev
1 month ago
[-]
A CTO that codes? Interesting indeed.
reply
simonw
1 month ago
[-]
That's pretty common in small companies. It's less common in large companies but can happen - you may use the "CTO" title for the founding engineer who still leads code and architecture, then hire someone under a different title (frequently "VP of Engineering") to handle the management / team growing side of the role.
reply
appplication
1 month ago
[-]
That sounds like a reasonable split to me, so much so I’m not sure I’d understand why you’d want the same person handling both code/architecture and management.
reply
subscribed
1 month ago
[-]
CTO in my company* remains SME on a several components, commits to several production repositories (and expects the most stringent PR checks), and maintains couple of small tool used by us and the customers.

Its not that rare I think.

*small fintech with couple of billions in the accounts, not a startup, not a Fortune 500 company

reply
dang
1 month ago
[-]
I'm not sure which comments you're finding weird, but I spot checked a bunch and didn't see anything that looked particularly bogus, other than https://news.ycombinator.com/item?id=47026348 and some trollish ephemera.

The upvotes on the submission look legit to me, as does the submission itself.

reply
sschueller
1 month ago
[-]
Sad that HN is now also getting boted by LLMs. People are just shameless. HN is one of the few places left where you can post / self promote something you have made only for people to take advantage of it.
reply
ZeWaka
1 month ago
[-]
The strangest part is the weird commenting accounts have pretty old account ages.
reply
quadrifoliate
1 month ago
[-]
I don't know if you're demonstrating reductio ad absurdum, but maybe that's because they are genuine? As people in the thread have pointed out, the author as well as their company is pretty well-known in software circles. They have had multiple projects discussed on HN in the past[1]. 2000 stars is not a lot given that [2].

I fail to understand why a ton of breathless blog posts about the process of AI-assisted coding are more interesting to HNers than some of the actual code (potentially, not claiming anything about it) written.

Maybe you or the GP could actually say what you think are "weird comments" and why you think this is being "boted"?

---------------

[1] https://hn.algolia.com/?dateRange=all&page=0&prefix=true&que...

[2] Why are people obsessed with star counts? I at least only star things to bookmark them, not vouch for them in any way. It does not seem unreasonable to me that 5 times as many people bookmarked the repo in the early days than are using it on npm. Also, npm is not necessary, the author shows at least 2 other ways to use it (direct download, link to GitHub pages) which will not show up in npm stats.

reply
sfdlkj3jk342a
1 month ago
[-]
> I love it. We need to see more of this.

> Use of semantic elements is an interesting take. I'll give it a try.

> Thank you for this, can’t wait to use. Minimalism at its best.

> Good one. Presentation is good too. Thanks

These are the kind of comments you see from Indians paid to boost Youtube content.

reply
jonathanstrange
1 month ago
[-]
They're probably just Indians using the framework saying "thanks." India has the largest population on Earth, they're close to 1.5 billion now. I think some people underestimate what that means.
reply
n_e
1 month ago
[-]
An explanation that would fit both the old accounts and the artificial comments would be that they were encouraged by the author to comment (which is against the HN rules).
reply
skeledrew
1 month ago
[-]
I'm on the other side of the planet, generally not a fan of web dev, and heartily agree with the sentiments in that comment.
reply
hkt
1 month ago
[-]
Same here, DevOps by trade, allergic to ridiculous frontend nonsense, my comment praised the framework.
reply
quadrifoliate
1 month ago
[-]
This seems like some pretty lazy analysis to be honest.

Following the first comment you quoted...

> I love it. We need to see more of this.

...shows that the author talks about using a “Chase card abroad” in a previous comment [1], which means they cannot be Indian as Chase doesn't issue cards or have substantial operations in India.

I don't want to run around following specific comment authors back through their threads, but as an Indian by birth it is pretty hurtful to see this kind of drive-by casual characterization of an population in a space like this. It also seems to be pretty contrary to the HN guidelines (“Please don't sneer, including at the rest of the community.”)

--------------

[1] https://news.ycombinator.com/item?id=46535775

reply
LaGrange
1 month ago
[-]
Those are fairly normal comments around here.
reply
debarshri
1 month ago
[-]
It is probably not bots. The reach of authors is pretty good. He actually loyal fan followers in india. You can see the same when he shows up on a podcast or talk.

I think theres alot indian developers who are hacker news as well as on github and other forums.

reply
JasonADrury
1 month ago
[-]
Why do all the comments look exactly like paid comment spam?
reply
debarshri
1 month ago
[-]
On second look. It could be spam. This is disappointing.
reply
e2le
1 month ago
[-]
Perhaps stolen accounts? I doubt every user is practising good security hygiene with a unique password per each account. Password leaks from other sites might well allow a motivated individual to hijack some here.
reply
leke
1 month ago
[-]
I could speculate that someone in the past had the business mindset to create thousands of accounts over multiple sites and offers the ability to loan them out for a period of time.
reply
gas9S9zw3P9c
1 month ago
[-]
If you search you can easily find sites to buy aged HN accounts, lots of them. Just like reddit accounts.
reply
BoneShard
1 month ago
[-]
AI Slop, basically a couple of LLM prompts will generate similar shit now.
reply
koakuma-chan
1 month ago
[-]
This is kind of misleading. It says it's an HTML UI library, then it says HTML + CSS, and then it says it also includes JavaScript. Why is this better than, say, DaisyUI?
reply
villgax
1 month ago
[-]
I just want something that's as easy to use as DaisyUI or even Bulma with one good set of components & themeing(beyond just palletes, like rounding, blur, transparency etc) & I'm good. For all the self-hosting model afficianados surely needing a build platform to create a blackhole of npm modules & internet connectivity for even a single build surely negates the entire point of a coding LLM if we still force it to deal with frontend
reply
koakuma-chan
1 month ago
[-]
You mean you want DaisyUI but with extended theming, like ability to make inputs, etc, rounded? This is also something I was considering.
reply
httpsterio
1 month ago
[-]
Iirc there's a few web components in there which would require js.
reply
dang
1 month ago
[-]
(Submitted title was "Oat – Ultra-lightweight, semantic, zero-dependency HTML UI component library" - we've replaced it now)
reply
akrauss
1 month ago
[-]
No Datepicker?
reply
bdcravens
1 month ago
[-]
As pointed out in another comment, it's under the form elements, not listed as a top-level component as many UI libraries do

https://oat.ink/components/#form

Which actually makes sense: Oat's driving philosophy seems to be to use and enhance native controls as much as possible, and the date picker is already a native type on the input element.

reply
ziml77
1 month ago
[-]
But there's no enhancement here. That's just the native date picker control with a bit of styling on the textbox portion of it.
reply
akrauss
1 month ago
[-]
Thanks, I missed that when looking through the component list on the top level.
reply
bartvk
1 month ago
[-]
I'm not a web dev, but doesn't HTML come with a date picker?
reply
LudwigNagasena
1 month ago
[-]
HTML also comes with a button and an accordion.
reply
visarga
1 month ago
[-]
This does not even need a LLM skill, just load the whole code up in context, so efficient.
reply
recursive
1 month ago
[-]
Doesn't even need a context either.
reply
deafpolygon
1 month ago
[-]
I love it. We need to see more of this.
reply
bartvk
1 month ago
[-]
I'm not a web dev, what do you love about it?
reply
deafpolygon
1 month ago
[-]
It leverages semantic html elements for styling… it may not seem like a huge deal on the surface, but it’s very useful in keeping html page sizes down, keeping the html itself simple to use, and so on.

there are other similar projects out, and i like them too.

reply
bartvk
1 month ago
[-]
Thanks! I get that.
reply