Biff – a batteries-included web framework for Clojure

47 TheWiggles 11 5/20/2025, 3:13:20 AM biffweb.com ↗

Comments (11)

jacobobryant · 5h ago
Hey HN. Since this has showed up here maybe a status update would be interesting? This continues to be my main side project--amusingly it's had more traction than any of the startups I tried to build with it. Over the past year I've been working on some experimental features for Biff that are meant to help with medium-to-large codebases[1] (I've been doing this as I rewrite one of my Biff apps from scratch). There haven't been many code releases in that time, so I've got a decently sized backlog of things I'd really like to get to. E.g. XTDB v2 is almost out of beta; once I finish the app rewrite, that's next on my list.

[1] https://biffweb.com/p/structuring-large-codebases/

pkphilip · 4h ago
Thank you for doing this. I am just checking out the Biff framework.

One part I would change is the dependence on htmx for html generation. I would really prefer an external template file into which we can replace fields

playworker · 3h ago
I might have misunderstood your comment but I don't think that's what htmx does, it just adds reactivity without needing to write JS, the HTML is represented in the project using Hiccup syntax which is essentially HTML in Clojure data structures - makes sense when code is data is a big part of the Lisp idea. It is an external template file into which you can replace fields, it's just a Clojure file too.
pkphilip · 1h ago
My mistake. I mean Hiccup (not Htmx). I prefer the approach of using external template files.
wpeterson · 24m ago
I didn't know anyone still used Clojure.
slifin · 1h ago
Nice to hear about Pathom being incorporated
Daviey · 4h ago
How often do the batteries need to be replaced?
jb1991 · 3h ago
“Batteries included” is an expression referring to technical dependencies and other matters and is not to be taken literally.
Daviey · 1h ago
Do you have an example of a Clojure web framework that doesn't include batteries?

ie, does https://luminusweb.com/ (or it's successor Kit, https://kit-clj.github.io/) includes batteries? They provide integrated solutions with templating, database access, authentication, and other common web application components pre-configured.

It's one of those weasel phrases that is poorly defined and has unclear boundaries.

I think Python first used it for the entire ecosystem:

  'The Python source distribution has long maintained the philosophy of "batteries included" -- having a rich and versatile standard library which is immediately available, without making the user download separate packages. This gives the Python language a head start in many projects.' 
- https://www.python.org/dev/peps/pep-0206/

So anything which doesn't require downloading separate packages, and provides a rich and versatile standard library is "batteries included"? Hugo in Golang, or Jekyll in Python are certainly batteries included then. Should all of them add this to their strapline?

The distinction becomes less clear when frameworks offer plugin ecosystems or when they're built atop other "batteries included" platforms. This creates a spectrum rather than a binary classification, leaving me quite skeptical of this adoption of marketing language.

brettatoms · 19m ago
Zodiac (https://github.com/brettatoms/zodiac) is a web framework/library that tries to fill a similar niche as Flask. It includes fewer batteries but supports extensions for extra functionality, see Zodiac Assets (https://github.com/brettatoms/zodiac-assets) and Zodiac SQL (https://github.com/brettatoms/zodiac-sql).

Zodiac itself does very little. Its mostly a preconfigured Ring app and a Reitit based router.

Full disclosure, I'm the author.

kgwxd · 23m ago
"Opinionated" might have been a more accurate weasel phrase, but I think everyone that cares, knows what they meant anyway.