From 8fbf93cddb27fe96891b7a7f3218742881dfaae1 Mon Sep 17 00:00:00 2001 From: Ian Storm Taylor Date: Mon, 11 Jan 2021 12:31:24 -0800 Subject: [PATCH] docs: Add referential equality to pitfalls (#731) Add a section about referential equality to pitfalls, with the simple example of using `indexOf` on a draft array to match an element. Fixes #730 --- docs/pitfalls.md | 19 +++++++++++++++++++ 1 file changed, 19 insertions(+) diff --git a/docs/pitfalls.md b/docs/pitfalls.md index 7f069bf7..ab308074 100644 --- a/docs/pitfalls.md +++ b/docs/pitfalls.md @@ -70,3 +70,22 @@ produce(state, draft => { }) }) ``` + +### Drafts aren't referentially equal + +Draft objects in Immer are wrapped in `Proxy`, so you cannot use `==` or `===` to test equality between an original object and its equivalent draft (eg. when matching a specific element in an array). Instead, you can use the `original` helper: + +```javascript +const remove = produce((list, element) => { + const index = list.indexOf(element) // this won't work! + const index = original(list).indexOf(element) // do this instead + if (index > -1) list.splice(index, 1) +}) + +const values = [a, b, c] +remove(values, a) +``` + +If possible, it's recommended to perform the comparison outside the `produce` function, or to use a unique identifier property like `.id` instead, to avoid needing to use `original`. + +