immutablejs:查找地图是否包含键值
immutablejs : find if map contains key value
我正在尝试确定我的不可变映射的某个部分是否包含某个键值,checked: true
,如果是,则在上层设置 checked: true。我正在查看的对象如下所示:
const memo = {
"Topics": {
"filters": {
"Psychological disorders": {
"filters": {
"Anxiety disorders": {
"filters": {},
"checked": true <-- check for this value at this level
}
}
}
},
"isOpen": false
}
}
注意:这个数据实际上是不可变的。
所以函数运行之后会变成这样:
const memo = {
"Topics": {
"filters": {
"Psychological disorders": {
"checked": true, <-- check true added
"filters": {
"Anxiety disorders": {
"filters": {},
"checked": true
}
}
}
},
"isOpen": false
}
}
我现在唯一可以访问的变量是 "Topics" 名称,所以我想找出是否有任何主题 -> 过滤器 -> 过滤器里面有 checked: true
。最初,我只是想 toJS() 这个备忘录,然后用 lodash 检查里面。
像这样:
_.find(memo['Topics'], _.flow(
_.property('filters'),
_.property('filters'),
_.partialRight(_.any, { checked: true })
));
我可以使用这些信息来修改对象,但我想知道是否可以在不将其从不可变中取出的情况下实现这一点。到目前为止,我已经试过了:
const nameCheck = 'Topics';
const hasCheckedFilters = memo.update(nameCheck, Map(),
(oldResult) => oldResult.update('filters', Map(),
(oldSection) => {
// filters inside this object has checked : true, .set('checked', true);
const fromImmutable = oldSection.toJS();
const checkForChecked = _.find(fromImmutable.filters, {checked:true});
if(checkForChecked) {
oldSectsion.set('checked', true);
}
}
)
)
);
这似乎不起作用,因为我没有在过滤器上循环。非常感谢任何输入,谢谢!
这使数据保持不变。我循环遍历 Topics.filters 中的每个 属性,然后检查 属性 是否有过滤器键。如果它确实循环通过它。如果子项中的 checked 为真,则在父项中将 checked 设置为 true 并 return 一个新地图。
const memo = {
"Topics": {
"filters": {
"Psychological disorders": {
"checked": false,
"filters": {
"Anxiety disorders": {
"filters": {},
"checked": true
}
}
}
},
"isOpen": false
}
};
let map = Immutable.fromJS(memo);
map.getIn(['Topics','filters']).forEach((item, i) => {
if(item.has('filters')){
item.get('filters').forEach(subItem => {
if(subItem.get('checked') === true){
map = map.setIn(['Topics', 'filters', i], item.set('checked', true));
}
});
}
});
console.log(JSON.stringify(map.toJS()));
我正在尝试确定我的不可变映射的某个部分是否包含某个键值,checked: true
,如果是,则在上层设置 checked: true。我正在查看的对象如下所示:
const memo = {
"Topics": {
"filters": {
"Psychological disorders": {
"filters": {
"Anxiety disorders": {
"filters": {},
"checked": true <-- check for this value at this level
}
}
}
},
"isOpen": false
}
}
注意:这个数据实际上是不可变的。
所以函数运行之后会变成这样:
const memo = {
"Topics": {
"filters": {
"Psychological disorders": {
"checked": true, <-- check true added
"filters": {
"Anxiety disorders": {
"filters": {},
"checked": true
}
}
}
},
"isOpen": false
}
}
我现在唯一可以访问的变量是 "Topics" 名称,所以我想找出是否有任何主题 -> 过滤器 -> 过滤器里面有 checked: true
。最初,我只是想 toJS() 这个备忘录,然后用 lodash 检查里面。
像这样:
_.find(memo['Topics'], _.flow(
_.property('filters'),
_.property('filters'),
_.partialRight(_.any, { checked: true })
));
我可以使用这些信息来修改对象,但我想知道是否可以在不将其从不可变中取出的情况下实现这一点。到目前为止,我已经试过了:
const nameCheck = 'Topics';
const hasCheckedFilters = memo.update(nameCheck, Map(),
(oldResult) => oldResult.update('filters', Map(),
(oldSection) => {
// filters inside this object has checked : true, .set('checked', true);
const fromImmutable = oldSection.toJS();
const checkForChecked = _.find(fromImmutable.filters, {checked:true});
if(checkForChecked) {
oldSectsion.set('checked', true);
}
}
)
)
);
这似乎不起作用,因为我没有在过滤器上循环。非常感谢任何输入,谢谢!
这使数据保持不变。我循环遍历 Topics.filters 中的每个 属性,然后检查 属性 是否有过滤器键。如果它确实循环通过它。如果子项中的 checked 为真,则在父项中将 checked 设置为 true 并 return 一个新地图。
const memo = {
"Topics": {
"filters": {
"Psychological disorders": {
"checked": false,
"filters": {
"Anxiety disorders": {
"filters": {},
"checked": true
}
}
}
},
"isOpen": false
}
};
let map = Immutable.fromJS(memo);
map.getIn(['Topics','filters']).forEach((item, i) => {
if(item.has('filters')){
item.get('filters').forEach(subItem => {
if(subItem.get('checked') === true){
map = map.setIn(['Topics', 'filters', i], item.set('checked', true));
}
});
}
});
console.log(JSON.stringify(map.toJS()));