immutableJS的使用
数据可变性的问题
在React开发中,我们总是会强调数据的不可变性: 无论是对于类组件中的state,还是redux中管理的state都是不建议直接去修改state本身的; 事实上在整个JavaScript编码过程中,数据的不可变性都是非常重要的;
数据的可变性引发的问题(案例):我们明明没有修改obj,只是修改了obj2,但是最终obj也被我们修改掉了;原因非常简单,对象是引用类型,它们指向同一块内存空间,两个引用都可以任意修改;
有没有办法解决上面的问题呢?进行对象的拷贝即可:Object.assign或扩展运算符 ,除此之外,想必大家知道更多的关于浅拷贝的方法。
这种对象的浅拷贝有没有问题呢?
(1)从代码的角度来说,没有问题,也解决了我们实际开发中一些潜在风险;
(2)从性能的角度来说,有问题,如果对象过于庞大,这种拷贝的方式会带来性能问题以及内存浪费;
有人会说,开发中不都是这样做的吗? 但是虽然从来如此,便是对的吗?
认识immutableJS
为了解决上面的问题,出现了Immutable对象的概念: Immutable对象的特点是只要修改了对象,就会返回一个
新的对象,旧的对象并不会发生改变;但是这样的方式就不会浪费内存了吗?为了节约内存