-
Notifications
You must be signed in to change notification settings - Fork 16
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
Fight the Spread #9
Comments
The spread detection is triggered in a case I don't understand I have an app state with the following part : {
referentials: {
clubs: {
isLoading: false,
ids: [
{
id: '/resamania/clubs/1',
schema: 'Club'
},
{
id: '/resamania/clubs/2',
schema: 'Club'
}
]
},
activities: {
isLoading: true,
ids: []
},
studios: {
isLoading: true,
ids: []
},
coaches: {
isLoading: true,
ids: []
}
}
} And a selector like this /**
* Returns the current state of referential loading
*
* @param {object} state
* @returns {boolean}
*/
export const getIsLoadingSomething = memoize(state =>
Boolean(Object.values(getReferentials(state)).find(value => value.isLoading))
); I'm getting
What I understand is that I'm iterating over all referential state and tho I'm killing optimization, but I don't know how I can do things differently. I don't want to hardcode the list of referentials. This is killing the magic of memoize-state a bit! I read this #5 (comment) but still don't understand |
To say the truth - the current behaviour of I am looking forward to disabling it. |
As continue of #5
Full object spread is a big problem - from point of view it is a performance killer, as long all object fields are set to be trackable, from another - this is why we emit a warning asking a user to reconsider selector, and that is not nice.
First version of "spread detection" just disables tracking during massive spread operation. Now - only record a fact, as long we have to emit a new "result" if any of fields got updated.
But how memoize-state tracks the keys?
get
hook, to trap any access to a property. This is how we know about something got accessed.Also
Missing
The idea:
What if add a special flag, to deproxify result outside of function call? Just split the calculation and the data you are going to pass throught.
Also we have to keep in mind - some spreads, are 100% "legal", as long "things just works that way". For example <Element {...props} /> - all the props are passed down to nested component.
Approach number 1
So "by result" will track the keys from "result" to be replaced by real values from "input". We still could have function memoized, but keeping "spreaded" paths updated.
As long object Objects and Arrays got proxies - not work for simple states. Meanwhile - could handle almost all the cases.
Approach number 2
Create a special function like
Object.assign
, to perform this operation without extra magic. "scanGuards" is the magic, I'll better keep of, but without them, we could not distinguish when values were "used", and when just "returned"spreaded, returned(used), used. If value was spreaded or returned - it still could be used.
Only b should be omitted.
Approach number 3
The text was updated successfully, but these errors were encountered: