This page is not created by, affiliated with, or supported by Slack Technologies, Inc.
2018-05-22
Channels
- # architecture (1)
- # aws (3)
- # beginners (78)
- # boot (33)
- # cider (49)
- # cljs-dev (3)
- # clojure (82)
- # clojure-berlin (2)
- # clojure-dusseldorf (14)
- # clojure-gamedev (75)
- # clojure-italy (15)
- # clojure-nl (2)
- # clojure-poland (9)
- # clojure-russia (1)
- # clojure-spec (11)
- # clojure-uk (91)
- # clojurescript (17)
- # core-async (2)
- # cursive (1)
- # data-science (3)
- # datascript (34)
- # datomic (13)
- # docs (2)
- # duct (32)
- # emacs (8)
- # fulcro (95)
- # instaparse (17)
- # jobs (2)
- # jobs-discuss (1)
- # jobs-rus (4)
- # leiningen (1)
- # luminus (1)
- # lumo (4)
- # mount (1)
- # nrepl (1)
- # off-topic (98)
- # onyx (13)
- # portkey (12)
- # re-frame (10)
- # reagent (11)
- # remote-jobs (4)
- # rum (3)
- # shadow-cljs (34)
- # specter (7)
- # sql (1)
- # tools-deps (8)
Yeah, I just wonder is that example is out of date
I haven't used track myself, so I'm not sure, but it's possible it is dated. CC @lee.justin.m
I don’t actually know how any of that internal tracking stuff works. @pesterhazy was thinking about doing a pass over that material
is there a way to expressly tell reagent that you want a re-render when a particular piece of state updates? i have an issue that I’m not getting updates with an external library using a render function because the deref doesn’t happen during render. I could just to a pointless deref and ignore the value but i feel like there must be something cleaner
I see some references to forceUpdate in the impl functions in reagent, maybe you can use those.
could you describe the issue in more detail?
there have been times where I wanted to rerender a component explicitly and more often than not in turns out there's a better way to do it (e.g. lifecycle methods)
this was an issue with using react virtualized’s InfiniteLoader component wrapping the Table component when rows can update locally (e.g. with click selection). the issue here is actually that i don’t know how to do it properly in javascript either. in the end i’m just wrapping and updating everything as props. i’m getting an annoying flicker on re-render but i’ll just live with it.
because everything is done with HOCs and render funcs, the only way to make this work sanely with reagent is to pass the reagent atoms as props so that you can be sure everything gets derefed
@lee.justin.m I think deref’ing at the appropriate time is a perfectly fine way to declare a dependency relationship, as reactivity systems like reagent are specifically built to pay attention to that, but I agree that it does not communicate intent well on its own. In a case like this I might do something like (def watch! deref)
in a utility namespace somewhere, so that instead of seeing @the-ratom
in the body of a function you would see (watch! the-ratom)
which is more obvious.
*unsure of the best name, maybe it depends on how you like to think about the way reagent works. depend-on!
, react-to!
also come to mind.
That’s an interesting idea. Basically I’ve been defeated a bit by the complexity of what I’m doing and the only problem I have is that I get a flicker when I update one of my rows. That usually means that the dom is getting an update it shouldn’t but wow is it hard to debug with these HOCs.