purescript-react-basic-hooks
purescript-react-basic-hooks copied to clipboard
Use Callback
Hi! Thanks a lot for this amazing package β¨
I cannot find an example of React.useCallback I see it was deprecated on what seems to be v5.x what is the correct way to "useCallback" in a hook?
Sorry if it is a silly question I'm learning purescript
Seems like you could just use useMemo?
fn' <- Hooks.useMemo deps \_ -> fn
would be the same as a hypothetical
fn' <- Hooks.useCallback deps fn
right?
Wow idk why the issue description was cut.
What i meant to say was: i see useCallback existed until v5 and now itβs gone, why? Is there a better way to do useCallback in PureScript?
Seems like you could just use
useMemo?fn' <- Hooks.useMemo deps \_ -> fnwould be the same as a hypothetical
fn' <- Hooks.useCallback deps fnright?
It seems about right, but the same applies in regular js, yet useCallback is exposed, why remove it? Coming from Reactjs is a bit weird not to have the same API.
I guess it's because it is "unnecessary" or something similar in PureScript?
Yeah, it's a combination of me naming some functions badly in previous versions plus it being redundant. Leaving it in would have caused confusing errors for those upgrading. I'm not opposed to adding it now, but also.. it's literally useMemo with the wrapper fn applied for you π
I was wondering more if the whole pattern was unnecessary or something, meaning declaring functions inside the body of a component does not cause React to re-render sub-components diffing a new function all the time, etc, but if it is the same case then having useCallback seems nice, it's something pretty well understood coming from reactjs to react-basic-hooks.
Yeah, it's a combination of me naming some functions badly in previous versions plus it being redundant. Leaving it in would have caused confusing errors for those upgrading. I'm not opposed to adding it now, but also.. it's literally
useMemowith the wrapper fn applied for you π
That's fine, considering PS commonality of having a bunch of ergonomic signatures (like fn, fn_, fn') I don't see why it would be bad to have useCallback as a shorthand, but I'm so noob in PS that maybe useCallback is not as widely used/necessary in PS as it is in JS?
But it's fine, I was mostly wondering about the former, I would "vote" for having it, but if it is trouble or confusing in PS, that's fine too, no need to make a change just for that.
That's true, I don't mind adding it.
For a little more background, I think PS devs are less likely to be thinking about reference equality at all, especially for functions, and just eating that performance cost until it actually becomes a problem. On the flip side, it's become fairly expected in JS-land and the more you see it the more you keep using it. In most cases it's a premature optimization. You can reach for these tools in PS if you need them (memo, UnsafeReference, useMemo, and [if added] useCallback), but it isn't as common.
It would be great if there would be useCallback: It is also documented in the react ecosystem and people might look for it. On the other hand it is helpful for people who don't know and are wondering why such a function exists and what problem it solves.
What option would you prefer @megamaddu ?
Adding useCallback implemented in terms of useMemo.
useCallback :: forall deps a. Eq deps => deps -> a -> Hook (UseMemo deps a) a
useCallback deps fn = useMemo deps (const fn)
or actually calling useCallback from the react library and adding a UseCallback hook.
Even though react docs say it's equivalent to, react team could decide to change internals of both functions or remove one of them in a breaking change in the future. And I personally tend to just exposing these functions from the react library and would go with the latter option (calling useCallback from the react library).
