@virtualstate/composite-key
v1.0.0
Published
[compositeKey & compositeSymbol](https://github.com/tc39/proposal-richer-keys/tree/master/compositeKey) implementation
Downloads
1,878
Readme
@virtualstate/composite-key
compositeKey & compositeSymbol implementation
Support
Test Coverage
Usage
Allows for multiple values to be "joined" together and used as a single key.
compositeKey
Returns a frozen object that can be used as a reference in place of the original arguments
The object can be used as a key in a WeakMap, or Map. The object can also be used in a WeakSet.
import { compositeKey } from "@virtualstate/composite-key";
const map = new WeakMap();
const array = [1, 2, 3];
map.set(compositeKey(array, 1), "Value");
map.get(compositeKey(array, 1)); // "Value"
map.get(compositeKey(array, 2)); // undefined
compositeSymbol
Returns a symbol that can be used as a reference in place of the original arguments.
The symbol can be used in most places, including keys of objects, and Maps. The symbol can also be used in a Set.
import { compositeSymbol } from "@virtualstate/composite-key";
const map = new Map();
const array = [1, 2, 3];
map.set(compositeSymbol(array, 1), "Value");
map.get(compositeSymbol(array, 1)); // "Value"
map.get(compositeSymbol(array, 2)); // undefined
createCompositeKey
Creates an isolated version of compositeKey
import { createCompositeKey } from "@virtualstate/composite-key";
const compositeKey = createCompositeKey();
const array = [1, 2, 3];
compositeKey(array, 1); // An object
createCompositeSymbol
Creates an isolated version of compositeSymbol
import { createCompositeSymbol } from "@virtualstate/composite-key";
const compositeSymbol = createCompositeSymbol();
const array = [1, 2, 3];
compositeSymbol(array, 1); // A symbol