immutable对象简介

一. 概述:

    一旦创建就不能更改的数据, 对该对象的任何修改或添加的操作都会返回一个新的immutable对象, 在创建新的数据时, 并不会改变旧数据; 为避免性能损耗, 使用了Structure Sharing(结构共享); Facebook工程师开发, 与React同时期出现;

二. 常用API:

1, get()和getIn()方法:
使用get(“item”)获取state中的值, 使用getIn([“header”,“item”])获取state中header下面的item, 不在使用state.item和state.header.item方法进行获取;
2, set()和merge()方法:
使用set(“item”, value)设置item的值为value, 使用merge({“item1”: value1, “item2”: value2})分别设置item1和item2的值;
3, 关于数组对象:
immutable中list对象有map()方法, 但是无法使用list[2]的方法拿到第3项的值, 需使用immutableObj.toJS()方法将immutable对象转换成普通对象之后再获取.
4, fromJS()和toJS()方法:
使用fromJS(obj)可以将普通obj对象转化为immutable对象, 使用immutableObj.toJS()方法可以将immutableObj转化为普通对象.

三. 优点:

1. 降低Mutable带来的复杂度, 不使用deepCopy和shallowCopy;
2. 节省内存空间;
3. 便于Undo/Redo, Copy/Paste; 

四. 缺点:

容易与原生对象混淆;
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值