javascript - ImmutableJs - 如何根据 map 中的位置检索 key

标签 javascript loops key immutable.js

我正在使用immutableJs

我的状态对象如下所示:

export const initialToolbarState = Map({
    temSelectionCtrl : Map({
        temSelect : true,
    }),
    functionalCtrl : Map({
        addEle : true,
        grpSelect : true,
        drawShape : true
    }),
    operationalCtrl : Map({
        zoomIn : true,
         zoomOut : true,
         pan : true,
         temSide : true
    }),
    referenceCtrl : Map({
        saveCtrl : true
    })
});

因此,有些对象的键具有 bool 值。

我想映射(循环)这些对象并获取它们的boolean 值决定是否渲染key。 Immutable 让我们可以使用其自定义的 map 函数来映射 Map。因此,以下内容有效,但未达到预期目的:

// map over the initialToolbarState Map object 
let ctrls = initialToolbarState.map(( eachToolbar ) => {
  // map over the child Map objects like temSelectionCtrl, functionalCtrl, operationalCtrl etc
  return eachToolbar.map(( eachCtrl, i ) => {
    // get the key corresponding to 'eachCtrl' value
    let propKey = eachToolbar.keyOf( eachCtrl );
      // propKey is always the first property (1st prop) of 'eachToolbar'
        console.log( propKey );
...

使用immutableJs,有没有办法获得与循环中当前“eachCtrl”值相对应的正确key?我能否确保 i 帮助将其指向与 key 匹配的正确

最佳答案

您可以在对象上再次使用.map。第二个参数是键,完整的参数签名为 (mapper (value: V, key: K, iter: this))

所以,这个片段:

initialToolbarState.map(( eachToolbar ) => {
  eachToolbar.map((value, key) => {
    console.log(key, ' ==> ', value);
  });
});

将记录:

temSelect  ==>  true
addEle  ==>  true
grpSelect  ==>  true
drawShape  ==>  true
// etc…

现在只需链接您的返回即可创建您需要的数据结构或使用您的 key 执行任何操作。

此外,重新考虑一下这个“ map 的 map ”是否是您正在解决的问题的最佳结构。如果您需要经常迭代,也许“ map 列表”会更好。您无法即时读取/更新单个项目,但如果您的列表仅包含几个项目,那么性能不会受到影响。

关于javascript - ImmutableJs - 如何根据 map 中的位置检索 key ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/43016879/

相关文章:

java - while循环不会改变变量的值

javascript - 如何使用 JavaScript 变量作为键访问 PHP 数组元素?

c++ - 检查 map c++中是否存在元素

javascript - Google Charts 将标记添加到折线图功能

javascript - Facebook 页面插件中的空 feed(嵌入 feed 小部件)

javascript - 如何处理 toastr 中按钮的点击事件?

c - 如何加速我的代码?

android - 如何从我的 Android 应用程序访问用户安装的 key 和证书?

javascript - onclick 返回函数未定义