-
Notifications
You must be signed in to change notification settings - Fork 0
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
useEffect, useContext, and other React utility apis. #3
Comments
useRef - we proved it's redundant. useEffect - "accepts a block that runs after the next render" - we already have useContext - "allows nested state within a nested components. i.e. component A has sub-views B and C. component A defines a context object, and component B and C has access to it via useContext." - it sounds pretty complicated and error-prone. useReducer - I don't know if I like it. We wanted simple stateful components and boom, we have a stateful component with own React/Elm architecture and two message types. Imagine a question: "So... I want to write a component - should I write it in Seed/Elm architecture or React/Seed/Elm architecture or use Seed's use_state (which is basically React's use_ref) or write a Rust/Typescript WebComponent?" It would be tough question for experienced developer who knows Seed, React, Elm, Rust, Javascript, Typescript and WebComponents, beginners will run away. useCallback / useMemo -
|
Yes all good points and keeping it simple is definitely a good strategy. It's worth considering the above only in so far as they are part of React's core Hook api and some prior users of React may want to reach for them. |
"It's worth considering the above only in so far as they are part of [X]'s core [Y] api and some prior users of [X] may want to reach for them."
|
agreed! |
Other than use_state React has a number of other utility apis that make working with their Hooks much more productive.
I have implemented most of them in some form however I want to really pin down what to include in a useful Seed api.
Here are the most commonly used React ones are.
useRef - is basically what we have with
use_state
basically synchronous updating of state with no forced re-rendering.useEffect - accepts a block that runs after the next render. This may be useful to programatically update certain items or trigger a re-render after a timeout. It ensures that your current component has been rendered.
useContext allows nested state within a nested components. i.e. component A has sub-views B and C. component A defines a context object, and component B and C has access to it via useContext.
useReducer creates a dispatch object that messages can be passed to. This then returns and updates the relevant state. This is as opposed to mutating state directly.
useCallback / useMemo Memoizes a value and only updates it if a dependency changes.
Of the above useMemo and useReducer would be most useful.
The use case for use_memo would be to cache an expensive value and only update it on request. For instance you could have a function that does a fetch request to update profile data:
This pattern would display a dummy profile until ready_bool.get() returns true in which case fetch_profile_async will update the memo with the loaded profile.
Another example where use_memo might be useful is when Seed evaluates every single view function which could include evaluation hundreds of
divs![]
and other node macros in a complex view. Usinguse_memo
you would only need to evaluate this once and the Node tree can then be memoized. i.e.This doesn't save any view diffing but does save the cost of creating the virtual dom in the first place.
The case for use_reducer means that logic can be separated from the view somewhat. It is like a mini seed message-update-view cycle. i.e. the classic counter example would be something like:
This lets one keep TEA style on a per view function basis and is more suited if there is more complex logic needed than a single state value. The view function is still self contained as a component and can be used wherever.
The text was updated successfully, but these errors were encountered: