This page is not created by, affiliated with, or supported by Slack Technologies, Inc.
2023-06-02
Channels
- # ai (1)
- # aleph (16)
- # announcements (1)
- # architecture (51)
- # babashka (32)
- # beginners (27)
- # calva (3)
- # clerk (1)
- # clojure (49)
- # clojure-art (1)
- # clojure-denver (6)
- # clojure-europe (70)
- # clojure-nl (1)
- # clojure-norway (56)
- # clojure-uk (2)
- # clojuredesign-podcast (4)
- # clojurescript (57)
- # clr (15)
- # community-development (3)
- # conjure (1)
- # core-async (10)
- # data-science (1)
- # datalog (2)
- # datomic (3)
- # emacs (12)
- # events (1)
- # gratitude (4)
- # honeysql (9)
- # hyperfiddle (86)
- # jobs (4)
- # off-topic (10)
- # pedestal (5)
- # portal (11)
- # practicalli (2)
- # reitit (7)
- # releases (3)
- # remote-jobs (1)
- # sql (15)
- # tools-build (8)
- # xtdb (4)
I see a Quick start guide linked in this channel (2018?) and also just looked over the official Getting Started guide on the Clojure website, but are there some blessed paths for getting started with web programming in Clojure? From the grapevine I've heard everybody is quite pleased about "shadows" or something and having REPLs in your browsers in your REPLs (or was it the other way around)? /s I know my way around HTML and CSS and have done a decent amount of WASM in Rust, but I have no React experience. I'm also hearing whispers of HTMX these days and the notion of embracing server-side work. What's a gent to do?
> What's a gent to do? Well, what do you need to do? A personal blog is one thing, a data-heavy SPA is another.
I will eventually be writing a web app that acts something like a dictionary. I suspect drawn input (from a mouse) from the user will also be required.
As part of the output, there will be some (hopefully) interactive graphs (the node-and-edge kind).
I'd say this is a good way to start then: https://github.com/shadow-cljs/quickstart-browser
Is it basically assumed that the React wrapper are to be used?
You can write code without any wrappers but that would be similar to going with plain JS instead of JSX. There are really thing wrappers that make interop with React pretty much seamless. And there are more abstracting wrappers that focus on other things.
If I were to go the React route, would learning it entirely through Clojure be good?
I did it that way but I'm hesitant to recommend it. If you enjoy reading source code as much as you enjoy reading prose, consider debugging minified JS bundles to be fun, don't get put off by 15 unrelated issues you know nothing about, then you're like me and I'd say "sure, go for it". But if not, then I don't know.
😆 I think I'll "consider my options"
But to be fair, learning vanilla React to a degree where you can build great stuff with it is not that much of a task. So you can easily get started with some React quick start, get comfortable with it, and then switch to CLJS and some React wrapper.
"Is it basically assumed that the React wrapper are to be used?" I would say React wrappers indeed have been the community favorite for a long time, but: • Hoplon/Javelin is also a veteran and slick way to go, and is being refurbished as we speak; • on the newer side we have Biff with HTMX; • I have a Web/MX project which handles the DOM directly; • and to me the coolest way to do the Web is Flutter, so we get mobile and desktop at the same time, almost for free. Check out #C03A6GE8D32 or again one of my libs, Flutter/MX supported in the #CKCBP3QF9 channel; • and if you do go with React, #CRRJBCX7S offers a nice functional interface (no Hiccup), and #C073DKH9P is excellent and very propular. Have fun!
Thanks for a breakdown of the options!
I'm noticing that js->clj
is leaving some objects as javascript objects, rather than converting them to clojurescript ones:
> (js->clj <some-json-value>)
#object[Object]
That's expected for anything that's not a plain JS object and doesn't satisfy IEncodeClojure
.
I see. The object has only flat data, so is there any way to convert the object to a 'plain js object'?
Then it's not a plain object. :) It has a constructor and you can't convert those objects in general - you have to figure out what is suitable in your specific case.
typeof
is misleading:
=> typeof(new Date())
'object'
That is surprising.
Does that object have a constructor
field that's set to undefined
?
type
in CLJS is just this:
(defn type
"Return x's constructor."
[x]
(when-not (nil? x)
(.-constructor x)))
And plain objects have js/Object
as their constructor.FWIW, here is my code: https://gist.github.com/LeifAndersen/5c27f64142203832fcf61b7eb65214c4
Ah, they're using Object.create(null)
. Seems like it ends up with something more plain than a plain JS object, heh.
I'd iterate over such an object directly to create a CLJS data structure.
So, if I were you, I'd just write my own js->clj
that would not only handle this particular case but would also be somewhat faster because you would be able to exclude a bunch of checks from there.
Oh, and there's an issue for it already: https://clojure.atlassian.net/browse/CLJS-2408
And, if you want, you can vote on it here to increase its priority: https://ask.clojure.org/index.php/5926/js-clj-does-not-work-on-objects-with-null-prototype?show=5926#q5926
> And, if you want, you can vote on it here to increase its priority: https://ask.clojure.org/index.php/5926/js-clj-does-not-work-on-objects-with-null-prototype?show=5926#q5926 Ah, didn't see your second link. Thanks. 🙂