ImmutableJs常用API学习
一、immutable简介
immutable即不可变的,immutable对象创建完之后不能被修改,对immutable对象的任何操作(属性或方法的增删改等)都会返回一个新的immutable对象。
immutable原理如下图动画所示:

当对象的属性树中的某个属性节点发生变化时,返回的新对象与原对象共用除[发生变化的属性和他的父节点]之外的其他属性节点。
immutable详细介绍见:https://www.w3ctech.com/topic/1595
二、Immutable API
-
fromJs将普通JS对象和数组转为Immutable的Map和List。(Deeply)

注:使用Js对象构造Immutable Map时,Js对象的属性总是字符串的。
-
is判断两个对象是否有相同的值。

-
hash返回31位整数值,此方法用来决定两个值是否相同以及如何存储这些值。

-
isImmutable判断对象是否是immutable的。

-
isCollection判断对象是否是集合(collection)或集合的子类(Map、List、Set等)。

三、List API
let List = Immutable.List;
-
toJS将List转为JS对象。
-
List用传递的参数创建一个新的List。

-
isList判断参数是否是List。

-
of用传递的参数创建一个新的List。

size

-
set按索引给List设置值,索引为负数时为从后往前数。

-
delete按索引删除元素,索引为负数时为从后往前数。

-
insert在指定的位置上插入元素。

-
clear清空List。

push

pop

-
shift返回删除List的第一个元素的新List。

-
unshift返回在List头部插入一个新元素的新List。

-
update返回更新了指定索引上元素值的新List,第二个参数(可选)表示当此索引上的元素没有被设置值时的默认值。

-
setIn按keyPath设置值


-
deleteIn按keyPath删除元素

concat

map

filter

filterNot

merge

first、last

indexOf、lastIndexOf

findIndex、findLastIndex

min、max

四、Map API
let Map = Immutable.Map;
-
toJS将Map对象转为JS对象。
-
Map创建一个新的immutable Map对象。

isMap

size

-
set返回新增/修改了属性为key值为value的新Map。

-
delete返回删除了key的新Map。

-
clear清空Map。

-
update类似List的update。

setIn

-
updateIn功能与setIn类似,只是可以通过updater函数更新值。

deleteIn

merge

mergeDeep

mergeWith

map

filter

get

has

getIn

hasIn
