为何用immutable.js呢。有了immutable.js能够大大提高react的性能。react
JavaScript 中的对象通常是可变的(Mutable),由于使用了引用赋值,新的对象简单的引用了原始对象,改变新的对象将影响到原始对象。如 foo={a: 1}; bar=foo; bar.a=2
你会发现此时 foo.a
也被改为了 2
。虽然这样作能够节约内存,但当应用复杂后,这就形成了很是大的隐患,Mutable 带来的优势变得得不偿失。为了解决这个问题,通常的作法是使用 shallowCopy(浅拷贝)或 deepCopy(深拷贝)来避免被修改,但这样作形成了 CPU 和内存的浪费。算法
而Immutable Data 就是一旦建立,就不能再被更改的数据。对 Immutable 对象的任何修改或添加删除操做都会返回一个新的 Immutable 对象。Immutable 实现的原理是 Persistent Data Structure(持久化数据结构),也就是使用旧数据建立新数据时,要保证旧数据同时可用且不变。同时为了不 deepCopy 把全部节点都复制一遍带来的性能损耗,Immutable 使用了 Structural Sharing(结构共享),即若是对象树中一个节点发生变化,只修改这个节点和受它影响的父节点,其它节点则进行共享数组
当state更新时,若是数据没变,也会去作virtual dom的diff,这就产生了浪费。而immutable能优化diff算法的性能。缓存
// 使用Immutable foo = Immutable.fromJS({a: {b: 1}}); //js对象转成Immutable对象 相反toJs() bar = foo.setIn(['a', 'b'], 2); // 深层使用 setIn 赋值 console.log(foo.getIn(['a', 'b'])); // 使用 getIn 取值,打印 1 console.log(foo === bar); // 打印 false
var myObject = {a:1,b:2,c:3}; Immutable.Seq(myObject).map(x => x * x).toObject(); // { a: 1, b: 4, c: 9 }
// 合并merge var map1 = Immutable.Map({a:1, b:2, c:3, d:4}); var map2 = Immutable.Map({c:10, a:20, t:30}); var obj = {d:100, o:200, g:300}; console.log(map1.merge(map2, obj).toJS()); // Map{}
// Map
var obj1 = Immutable.Map({a:1, b:2, c:3});
var obj2 = obj1.set('b', 50); // set
console.log(obj1.get('b'),obj2.get('b')); // get 2 50
var alpha = Immutable.Map({a:1, b:2, c:3, d:4});
console.log(alpha.map((v, k) => k.toUpperCase()).join());// 'A,B,C,D'数据结构
// List
const list = Immutable.List([ 'a', 'b', 'c' ])
const result = list.update(2, val => val.toUpperCase())
console.log("===>",result.toJS())dom
var map = Immutable.fromJS(obj); map.get("1"); // "one" map.get(1); // undefined
var nested2 = nested.mergeDeep({a:{b:{d:6}}}); // Map { a: Map { b: Map { c: List [ 3, 4, 5 ], d: 6 } } } nested2.getIn(['a', 'b', 'd']); // 6 var nested3 = nested2.updateIn(['a', 'b', 'd'], value => value + 1); // Map { a: Map { b: Map { c: List [ 3, 4, 5 ], d: 7 } } } var nested4 = nested3.updateIn(['a', 'b', 'c'], list => list.push(6)); // Map { a: Map { b: Map { c: List [ 3, 4, 5, 6 ], d: 7 } } }
getInitialState() { return { data: Map({ times: 0 }) } }, handleAdd() { this.setState({ data: this.state.data.update('times', v => v + 1) }); // 这时的 times 并不会改变 console.log(this.state.data.get('times')); }
this.state={ searcnfinanceTypeListAll: Immutable.fromJS([]) } changeState=()=>{ this.setState({searcnfinanceTypeListAll:Immutable.fromJS(typeList)}); }
建议把 this.state
写成 Immutable 对象 性能