memo/readme.md
James Brumond 13a64c0d2d
All checks were successful
Build and test / build-and-test (18.x) (push) Successful in 13s
Build and test / build-and-test (20.x) (push) Successful in 12s
add 3 caching implementations for various use cases
2023-08-26 15:59:05 -07:00

981 B

In-memory caching/memoization utilities


Install

npm install --save @js/memo

Usage

import { memo } from '@js/memo';

function get_data_from_slow_source(name: string) : string {
	// ....
}

const get_data_cached = memo({
	func: get_data_from_slow_source,
	ttl: 30_000,
});

Custom cache key generation

import { memo } from '@js/memo';

interface SomeObject {
	id: string;
	foo: string;
	bar: number;
	baz: {
		qux: string;
	};
}

function get_data_from_slow_source(obj: SomeObject) : string {
	// ....
}

const get_data_cached = memo({
	func: get_data_from_slow_source,
	ttl: 30_000,

	// Pull just the `id` field from the first parameter to use
	// as the cache key
	key([ obj ]) {
		return obj.id;
	},
});

Simple functions with no params


import { memo_simple } from '@js/memo';

function get_data_from_slow_source() : string {
	// ....
}

const get_data_cached = memo_simple(30_000, get_data_from_slow_source);