solarhorizon / rodux-hooks Goto Github PK
View Code? Open in Web Editor NEWRoact hooks for Rodux
License: MIT License
Roact hooks for Rodux
License: MIT License
Currently, in order to use the Rodux hooks in child components, we need to pass the context exported by Rodux Hooks next to RoactRodux.StoreProvider
at top level of the tree.
By using the StoreContext
exported by RoactRodux, the above step is no longer necessary.
See: https://github.com/Roblox/roact-rodux/blob/master/src/StoreContext.lua
useSelector only uses the updated selector provided to it when the store changes. However, if the component it's used in re-renders for unrelated reasons and the selector changes, useSelector simply re-uses the previous value. This leads to situations where a changing prop that determines the selector will result in a desync between the component and the rodux hook.
local function EggContents(props, hooks)
local selectedEgg: string = props.selectedEgg
print(selectedEgg) -- "selectedEgg2"
local eggInfo = RoduxHooks.useSelector(hooks, function(state)
print(selectedEgg) -- "selectedEgg"
return state.liveOpsData.Eggs[selectedEgg]
end)
print(eggInfo) -- selectedEgg's info
local tiles = {}
-- ...
Currently to use RoduxHooks you're required to pass along the RoactHooks object to every selector you use. This seemed innocuous at first but after using hundreds of selectors in our project it starts to add up. I believe using a hooks
field passed to the provider context internally in the useCustomSelector
and useSelector
implementations would fix this issue.
One caveat I can see to this is that you would need a top-level wrapper component around the provider component to obtain the RoactHooks object. This could introduce backwards compatibility issues but would overall be a cleaner implementation on large codebases.
A declarative, efficient, and flexible JavaScript library for building user interfaces.
๐ Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
An Open Source Machine Learning Framework for Everyone
The Web framework for perfectionists with deadlines.
A PHP framework for web artisans
Bring data to life with SVG, Canvas and HTML. ๐๐๐
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
Some thing interesting about web. New door for the world.
A server is a program made to process requests and deliver data to clients.
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
Some thing interesting about visualization, use data art
Some thing interesting about game, make everyone happy.
We are working to build community through open source technology. NB: members must have two-factor auth.
Open source projects and samples from Microsoft.
Google โค๏ธ Open Source for everyone.
Alibaba Open Source for everyone
Data-Driven Documents codes.
China tencent open source team.