@ -14,14 +14,15 @@ Dealing with immutable data in JavaScript is more difficult than in languages de
If you mutate data like this:
If you mutate data like this:
```javascript
```js
myData.x.y.z = 7;
myData.x.y.z = 7;
// or...
myData.a.b.push(9);
myData.a.b.push(9);
```
```
you have no way of determining which data has changed since the previous copy is destroyed. Instead, you need to create a new copy of `myData` and change only the parts of it that need to be changed. Then you can compare the old copy of `myData` with the new one in `shouldComponentUpdate()` using triple-equals:
you have no way of determining which data has changed since the previous copy is overriden. Instead, you need to create a new copy of `myData` and change only the parts of it that need to be changed. Then you can compare the old copy of `myData` with the new one in `shouldComponentUpdate()` using triple-equals:
```javascript
```js
var newData = deepCopy(myData);
var newData = deepCopy(myData);
newData.x.y.z = 7;
newData.x.y.z = 7;
newData.a.b.push(9);
newData.a.b.push(9);
@ -29,7 +30,7 @@ newData.a.b.push(9);
Unfortunately, deep copies are expensive, and sometimes impossible. You can alleviate this by only copying objects that need to be changed and by reusing the objects that haven't changed. Unfortunately, in today's JavaScript this can be cumbersome:
Unfortunately, deep copies are expensive, and sometimes impossible. You can alleviate this by only copying objects that need to be changed and by reusing the objects that haven't changed. Unfortunately, in today's JavaScript this can be cumbersome:
```javascript
```js
var newData = extend(myData, {
var newData = extend(myData, {
x: extend(myData.x, {
x: extend(myData.x, {
y: extend(myData.x.y, {z: 7}),
y: extend(myData.x.y, {z: 7}),
@ -42,7 +43,7 @@ While this is fairly performant (since it only shallow copies `log n` objects an
`update()` provides simple syntactic sugar around this pattern to make writing this code easier. This code becomes:
`update()` provides simple syntactic sugar around this pattern to make writing this code easier. This code becomes:
```javascript
```js
var newData = React.addons.update(myData, {
var newData = React.addons.update(myData, {
x: {y: {z: {$set: 7}}},
x: {y: {z: {$set: 7}}},
a: {b: {$push: [9]}}
a: {b: {$push: [9]}}
@ -55,8 +56,45 @@ The `$`-prefixed keys are called *commands*. The data structure they are "mutati
## Available commands
## Available commands
* `{$push: array}``push()` all the items in `array` on the target
* `{$push: array}``push()` all the items in `array` on the target.
* `{$unshift: array}``unshift()` all the items in `array` on the target
* `{$unshift: array}``unshift()` all the items in `array` on the target.
* `{$splice: array of arrays}` for each item in `array()` call `splice()` on the target with the parameters provided by the item.
* `{$splice: array of arrays}` for each item in `array()` call `splice()` on the target with the parameters provided by the item.
* `{$set: any}` replace the target entirely
* `{$set: any}` replace the target entirely.
* `{$merge: object}` merge the keys of `object` with the target
* `{$merge: object}` merge the keys of `object` with the target.
* `{$apply: function}` passes in the current value to the function and updates it with the new returned value.