I think they mean it won't behave as expected if the array contains similar objects that have different references
const originalObject = {} const boundToOriginalObject = originalObject const newObjectThatLooksLikeOriginal = {} const arr = [originalObject, boundToOriginalObject, newObjectThatLooksLikeOriginal] const dedupe = [ ...new Set(arr)] dedupe // [{}, {}] // deduping removes the duplicate reference but not similar objects const mutation = {a: 1} Object.assign(dedupe[1], mutation) originalObject // {} newObjectThatLooksLikeOriginal // { a: 1 } // this proves which references remained in the deduped array prior to mutation
It might be helpful to clarify that dedupe will remove duplicate bindings but not similar objects with a different binding
Are you sure you want to hide this comment? It will become hidden in your post, but will still be visible via the comment's permalink.
Hide child comments as well
Confirm
For further actions, you may consider blocking this person and/or reporting abuse
We're a place where coders share, stay up-to-date and grow their careers.
I think they mean it won't behave as expected if the array contains similar objects that have different references
It might be helpful to clarify that dedupe will remove duplicate bindings but not similar objects with a different binding