This page is not created by, affiliated with, or supported by Slack Technologies, Inc.
2016-09-07
Channels
- # admin-announcements (2)
- # arachne (1)
- # bangalore-clj (2)
- # beginners (39)
- # boot (349)
- # cider (31)
- # clara (2)
- # cljs-dev (9)
- # cljsjs (67)
- # cljsrn (7)
- # clojure (300)
- # clojure-art (4)
- # clojure-greece (11)
- # clojure-hk (3)
- # clojure-israel (1)
- # clojure-italy (17)
- # clojure-japan (1)
- # clojure-russia (33)
- # clojure-sg (2)
- # clojure-spec (41)
- # clojure-uk (86)
- # clojurescript (123)
- # clojurex (3)
- # code-reviews (1)
- # component (6)
- # crypto (1)
- # cursive (36)
- # datomic (32)
- # devcards (3)
- # emacs (11)
- # events (3)
- # funcool (4)
- # luminus (10)
- # om (28)
- # onyx (88)
- # pedestal (2)
- # re-frame (84)
- # reagent (7)
- # ring-swagger (3)
- # specter (33)
- # sql (2)
- # vim (21)
is it common practice if writing a “composable” component that accepts arbitrary children to simply do this:
(defn wrapper [props & children]
[:div “my wrapper”
(first children)])
in order to “unwrap” the spread &
? Is there a more idiomatic way?Not sure if it is idiomatic, but i generally do something like this
(defn wrapper [props & children]
(into [:div "my wrapper"] children))
if doing this, just good to note that the component will rerender a lot ... so good for leafy components, not sure about top-level ones
ah yes, thanks @gadfly361
@gadfly361: i’m not sure that it would re-render any more than it would sans wrapper. If those props or children have cause to change, whatever is receiving them is going to re-render
@eyelidlessness I guess I am thinking of a specific scenario when you are iterating over a list (like rows in a table or something). Normally, you'd add a :key to the metadata to help React know that certain items don't need to be updated ... with into, it will rerender the entire list every time it tries to render (while also silencing the keys warning).