Key based index store.
$ npm i key-index
Import
import keyIndex from "key-index"
Create an instance
let initer = (pointer: string) => {
return {name: pointer}
}
let index = keyIndex(initer)
When querying a key that is not assigned to a value yet, one is automatically created via the given initer
function.
let a = index("keyA") // {name: "keyA"}
a.prop = "val"
index("keyA") // {name: "keyA", prop: "val"}
(Mostly for debugging purposes) you can also query the whole document
let a = index() // Map: {
// "keyA": {
// "name": "keyA"
// "prop": "val"
// }
// }
The index is stored in a Map by default. If youd like to use a regular object as index instead use
import { constructObjectIndex as keyIndex } from "key-index"
All functionality is the same here. The only difference is the underlying technology used.
Note: that native objects do only support strings | number | symbol as indices!
This is the default initer
keyIndex(/* () => {return {}} */)
You can use values directly. If your use case does only need one value.
let valueIndex = keyIndex((key) => key)
valueIndex("keyA") // "keyA"
In that (and every other) case you can change the value like so:
valueIndex("keyA", "keyAValue") // "keyAValue"
valueIndex("keyA") // "keyAValue"
If using your use case requires nested indices consider this
let nestedIndex = keyIndex(() => keyIndex(/* () => {return {}} */))
nestedIndex("keyA")("keyB") // {}
Querying the whole document does also work here
nestedIndex("keyA")("keyB").key = "val"
nestedIndex("keyA")("keyC").key = "val"
nestedIndex("keyD")("keyE").key1 = "val1"
nestedIndex("keyD")("keyE").key2 = "val2"
nestedIndex() // Map {
// "keyA": Map {
// "keyB": { key: "val" }
// "keyC": { key: "val" }
// }
// "keyD": Map {
// "keyE": { key1: "val1", key2: "val2" }
// }
// }
Note: Depending on the underlying technology (maps / objects) this may yield slightly different results (all maps would be regular objects).
All feedback is appreciated. Create a pull request or write an issue.