An efficient ordered hash for javascript. Unlike with objects, each entry in the hash has an index. All methods are O(1) except for remove
, which is an optimized O(n).
Create a new empty hash
var Ohash = require('ordered-hash')
var h = Ohash.create()
O(1)
Insert a new key/value pair at the end of the hash. Throws an exception if the key already exists. Returns the hash.
h.push('x', 'a')
Ohash.push('y', 'b', h)
O(1)
Insert a new key/value pair at the beginning. Will get index of 0. Unlike with arrays, this is O(1). Throws an exception if the key already exists. Returns the hash
h.unshift('x', 'a')
Ohash.unshift('x', 'a', h)
O(1)
Set an existing key/value pair to a new value. Doesn't affect its index. Throws an exception if the key doesn't exist. Returns the hash
h.set('x', 'b')
Ohash.set('x', 'b', h)
O(1)
Return the value for a key. Throws an exception if the key doesn't exist.
var val = h.get('x')
var val = Ohash.get('x', h)
O(1)
Return the index for a key. Throws an exception if the key doesn't exist.
var idx = h.getIndex('x')
var idx = Ohash.getIndex('x', h)
O(1)
Return the length of the hash
var len = h.length()
var len = Ohash.length(h)
O(1)
Swap the indexes of two keys. Throws an exception if either key doesn't exist. Returns the hash.
h.swap('x', 'y')
Ohash.swap('x', 'y', h)
O(1)
Remove the first key/value pair in the hash. Unlike with arrays, this is O(1). Throws an exception if the hash is empty. Returns a pair of the key and val.
var [key, val] = h.shift()
var [key, val] = Ohash.shift(h)
O(1)
Remove the last key/value pair in the hash. Throws an exception if the hash is empty. Returns a pair of the key and val.
var [key, val] = h.pop()
var [key, val] = Ohash.pop(h)
O(1)
Remove a key/value pair at any point in the hash. Will adjust the other indexes in the hash. Throws an exception if the key doesn't exist. Returns the val.
var val = h.remove('x')
var val = Ohash.remove('x', h)
O(n) where n is the distance from the key's index to either the beginning or end of the hash, whichever is shorter.