问题
Unfortunately the documentation is very sparse :
https://facebook.github.io/immutable-js/docs/#/Map/getIn
Does anyone have an example? I am guessing that if I have a myObject like so :
a: {
b:{
c:"banana"
}
}
that
myObject.getIn(["a", "b", "c"])
will return banana.
However the immutable objects can also be map objects which leaves me thoroughly confused.
回答1:
Shortly:
map.getIn(["a", "b", "c"]) is a shortcut to map.get("a").get("b").get("c")
In details:
You have probably got into one of the fromJS traps. Calling :
const map = Immutable.fromJS({a: {b: {c: "banana"}}});
creates a Map with only key a, which's value is also a Map with only key b, which's value is also a Map with only key c and value banana.
With other words fromJS goes into the deep of the object provided, and defines Map for each Object and a List for each Array
With this example, calling map.getIn(["a", "b", "c"]) is kind of a shortcut to map.get("a").get("b").get("c")
But if you define map as a Map:
const map = new Immutable.Map({a: {b: {c: "banana"}}});
it creates a Map, with only key a, which's value is plain object {b: {c: "banana"}}, and calling a map.get("a").get("b").get("c") will throw you something like get is not a function, since map.get("a") will return {b: ...} plain object.
Same reasons are why map.getIn(["a", "b", "c"]) will not work as you might expect.
来源:https://stackoverflow.com/questions/43515723/what-does-getin-do-in-immutable-js