Package detail

immutablejs-record-memoize

Soreine1kMIT1.0.1

Memoize methods and properties of ImmutableJS.Record

immutable, record, memoize

readme

immutablejs-record-memoize

npm

Memoize methods or properties of any ImmutableJS.Record. Also works on any immutable object prototype.

Install

yarn add immutablejs-record-memoize

Usage

With ImmutableJS.Record:

import memoize from 'immutablejs-record-memoize';

class ExampleRecord extends Record({}) {
    noArguments() {
        // ...
    },

    withArguments(a, b, c) {
        // ...
    }
}

memoize(ExampleRecord.prototype, ['noArguments', 'withArguments']);

// Use ExampleRecord as usual

For other object's prototypes:

import memoize from 'immutablejs-record-memoize';

function ExampleObject() {
    constructor() {
        // ...
    }
}

ExampleObject.prototype = {
    noArguments() {
        // ...
    },

    withArguments(a, b, c) {
        // ...
    }
};

// Memoize methods with no arguments
memoize(ExampleObject.prototype, ['noArguments', 'withArguments']);

// Use ExampleObject as usual

Reference

memoize

Memoize the given properties of the given prototype object. The prototype is mutated.

Arguments:

  • prototype: Object The object prototype that should have its properties memoized.
  • properties: string[] The list of properties names that should be memoized

Returns: void

Credits

Implementation is taken from Slate. https://github.com/ianstormtaylor/slate/blob/master/src/utils/memoize.js

Thank you to:

changelog

Release notes

All notable changes to this project will be documented in this file. This project adheres to Semantic Versioning.

Unreleased

1.0.1

  • Improved memory performance by using WeakMap and a global cache (no longer adding __cache to object instances). Tested for Immutable 4 as well.