web-dev-qa-db-ja.com

JavaScriptのハッシュテーブル

JavaScriptでハッシュテーブルを使用しており、ハッシュテーブルに次の値を表示したい

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

次のコードを見つけました。次のデータに対して機能します。

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

ハッシュテーブルに1 [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>

どうすればいいのですか?

41
venkatachalam

上記の関数を使用すると、次のことができます。

_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)を使用するとすべての関数などが取得されるため、反復するのは難しくなりますが、必要に応じてこれで十分かもしれません。

74
roryf

ルックアップテーブルに静的な値を保存するだけでよい場合は、 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
32
Shalom Craimer

JavaScriptハッシュテーブルの実装 jshashtable を使用できます。文字列だけでなく、任意のオブジェクトをキーとして使用できます。

8
Tim Down

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
4
anarchocurious