具有可变维度的 JavaScript 函数数组

标签 javascript arrays

我正在编写一个函数,它在更多维度上索引一维数组。用户可以选择索引的深度。

例如。

var store = ["Alaska", "Alabama", "North Korea", "South Korea"];

用户可以选择例如深度1。这意味着它将以字符串的第一个字符作为索引

index["a"] = ["Alaska", "Alabama"];
index["n"] = ["North Korea"];

如果用户选择 depth = 2 则它将是索引为两个开始字符的二维数组

index["a"]["l"] = ["Alaska", "Alabama"];

等等

我如何在 JavaScript 中完成一个可以填充变量维度数组的函数?

var indexthis = function(store,depth)
{
  if(depth == "undefined")
  {depth =1;}
//any Suggestions to go on?
};

问候

最佳答案

这个函数:

function indexWord(index, word, letters) {
    var letter;
    if (!letters) letters = word.split("");
    while (letters.length) {
        letter = letters.shift().toLowerCase();
        if (!(letter in index)) index[letter] = {_items: []};
        index[letter]._items.push(word);
        indexWord(index[letter], word, letters);
    }
}

这样调用:

var store = ["Alaska", "Alabama", "North Korea", "South Korea"],
    index = {}, i;

for (i = 0; i < store.length; i++) {
    indexWord(index, store[i]);
}

为您提供以下索引:

{
  a: {
    _items: ["Alaska", "Alabama"],
    l: {
      _items: ["Alaska", "Alabama"],
      a: {
        _items: ["Alaska", "Alabama"],
        s: {
          _items: ["Alaska"],
          k: {
            _items: ["Alaska"],
            a: {
              _items: ["Alaska"]
            }
          }
        },
        b: {
          _items: ["Alabama"],
          a: {
            _items: ["Alabama"],
            m: {
              _items: ["Alabama"],
              a: {
                _items: ["Alabama"]
              }
            }
          }
        }
      }
    }
  },
  n: {
    _items: ["North Korea"],
    o: {
      _items: ["North Korea"],
      r: {
        _items: ["North Korea"],
        t: {
          _items: ["North Korea"],
          h: {
            _items: ["North Korea"],
            " ": {
              _items: ["North Korea"],
              k: {
                _items: ["North Korea"],
                o: {
                  _items: ["North Korea"],
                  r: {
                    _items: ["North Korea"],
                    e: {
                      _items: ["North Korea"],
                      a: {
                        _items: ["North Korea"]
                      }
                    }
                  }
                }
              }
            }
          }
        }
      }
    }
  },
  s: {
    _items: ["South Korea"],
    o: {
      _items: ["South Korea"],
      u: {
        _items: ["South Korea"],
        t: {
          _items: ["South Korea"],
          h: {
            _items: ["South Korea"],
            " ": {
              _items: ["South Korea"],
              k: {
                _items: ["South Korea"],
                o: {
                  _items: ["South Korea"],
                  r: {
                    _items: ["South Korea"],
                    e: {
                      _items: ["South Korea"],
                      a: {
                        _items: ["South Korea"]
                      }
                    }
                  }
                }
              }
            }
          }
        }
      }
    }
  }
}

其中 index["a"]["l"]._itemsindex.a.l._items 可用于访问 ["Alaska", “阿拉巴马州”]

关于具有可变维度的 JavaScript 函数数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24654432/

相关文章:

Javascript 函数数组删除项目

javascript - 使用 shift() 和 push() 循环数组值与使用计数器变量相比,最佳方法是什么?

javascript - React Native this.props.screenProps.mapLoc.markers.map 不是一个函数

java - 从 Java 中的输入文件数据创建的数组中创建格式化表

javascript - 如何从数组列表创建数组对象。 (使用 Angular js)

java - 如何停止将已添加的值从 JCombobox 添加到 JTable

javascript - 在 Immutable.js 中扩展记录

javascript - 使用数组替换多个字符串

c++ - 使用 memset 而不是 for 循环来初始化 int 时出现段错误**

javascript - CKEditor - 未捕获的类型错误 : Cannot read property 'clearCustomData' of null in Chrome