Хеш-таблица в JavaScript - PullRequest
       36

Хеш-таблица в JavaScript

41 голосов
/ 19 января 2009

Я использую хеш-таблицу в JavaScript и хочу показать следующие значения в хеш-таблице

one   -[1,10,5]
two   -[2]
three -[3, 30, 300, etc.]

Я нашел следующий код. Работает для следующих данных.

   one  -[1]
   two  -[2]
   three-[3]

Как назначить одно- [1,2] значения хеш-таблице и как получить к ней доступ?

<script type="text/javascript">
    function Hash()
    {
        this.length = 0;
        this.items = new Array();
        for (var i = 0; i < arguments.length; i += 2) {
            if (typeof(arguments[i + 1]) != 'undefined') {
                this.items[arguments[i]] = arguments[i + 1];
                this.length++;
            }
        }

        this.removeItem = function(in_key)
        {
            var tmp_value;
            if (typeof(this.items[in_key]) != 'undefined') {
                this.length--;
                var tmp_value = this.items[in_key];
                delete this.items[in_key];
            }
            return tmp_value;
        }

        this.getItem = function(in_key) {
            return this.items[in_key];
        }

        this.setItem = function(in_key, in_value)
        {
            if (typeof(in_value) != 'undefined') {
                if (typeof(this.items[in_key]) == 'undefined') {
                    this.length++;
                }

                this.items[in_key] = in_value;
            }
            return in_value;
        }

        this.hasItem = function(in_key)
        {
            return typeof(this.items[in_key]) != 'undefined';
        }
    }

    var myHash = new Hash('one',1,'two', 2, 'three',3 );

    for (var i in myHash.items) {
        alert('key is: ' + i + ', value is: ' + myHash.items[i]);
    }
</script>

Как мне это сделать?

Ответы [ 4 ]

74 голосов
/ 19 января 2009

Используя функцию выше, вы должны сделать:

var myHash = new Hash('one',[1,10,5],'two', [2], 'three',[3,30,300]);

Конечно, будет работать и следующее:

var myHash = {}; // New object
myHash['one'] = [1,10,5];
myHash['two'] = [2];
myHash['three'] = [3, 30, 300];

, поскольку все объекты в JavaScript являются хеш-таблицами! Однако было бы сложнее выполнить итерации, поскольку использование foreach(var item in object) также даст вам все его функции и т. Д., Но этого может быть достаточно в зависимости от ваших потребностей.

32 голосов
/ 19 января 2009

Если все, что вы хотите сделать, это сохранить некоторые статические значения в таблице поиска, вы можете использовать Object Literal (тот же формат, который используется JSON ), чтобы сделать это компактно:

var table = { one: [1,10,5], two: [2], three: [3, 30, 300] }

И затем получить к ним доступ, используя синтаксис ассоциативного массива JavaScript:

alert(table['one']);    // Will alert with [1,10,5]
alert(table['one'][1]); // Will alert with 10
8 голосов
/ 09 июля 2010

Вы можете использовать мою реализацию хэш-таблицы JavaScript, jshashtable . Он позволяет использовать любой объект в качестве ключа, а не только строки.

3 голосов
/ 25 июля 2013

Интерпретатор Javascript изначально сохраняет объекты в хэш-таблице. Если вы беспокоитесь о загрязнении цепочки прототипов, вы всегда можете сделать что-то вроде этого:

// Simple ECMA5 hash table
Hash = function(oSource){
  for(sKey in oSource) if(Object.prototype.hasOwnProperty.call(oSource, sKey)) this[sKey] = oSource[sKey];
};
Hash.prototype = Object.create(null);

var oHash = new Hash({foo: 'bar'});
oHash.foo === 'bar'; // true
oHash['foo'] === 'bar'; // true
oHash['meow'] = 'another prop'; // true
oHash.hasOwnProperty === undefined; // true
Object.keys(oHash); // ['foo', 'meow']
oHash instanceof Hash; // true
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...