npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

kvcobj

v0.1.0-6

Published

Key-value coding for javascript objects.

Downloads

21

Readme

KVCObject

Key-value coding for javascript objects. Gives access to values in object trees via keypaths. Emits update events as they come, with minimal changesets. Good for finding deltas for new versions of objects, and linking views to models.

Public API

Methods

  • (constructor)([< object >options])
    Creates and returns a new KVCObject.
    Valid options:

    • delimiter - string - The string to use as delimiter between keys. Default: '.'
  • setObject(< object >object, [< bool >silent]) - (void)
    Sets the current root, overwriting the existing root. If this leads to a change of the object, an update (and possibly also a create or delete , see below) event will be triggered, unless silent is set to true.

  • getObject() - (object)
    Returns the current root as a normal object.

  • setObjectForKeypath(< object >object, < string >rootKeypath, [< bool >silent]) - (void)
    Sets all values of object, where rootKeypath will be the keypath to the root of the object. If this leads to a change of the object, an update (and possibly also a create or delete, see below) event will be triggered, unless silent is set to true.

  • getObjectForKeypath(< string >keypath) - (object)
    Returns the object from keypath.

  • setValueForKeypath(< non-object >value, < string >keypath, [< bool >silent]) - (void)
    Sets value at keypath. If this leads to a change of the object, an update (and possibly also a create or delete , see below) event will be triggered, unless silent is set to true.

  • getValueForKeypath(< string >keypath) - (non-object)
    Returns the value at keypath.

  • commit() - (void)
    Commits uncommited changes made with silent set to true. This leads to change events being emitted.

Events

  • create(< object >created)
    Emitted when a value (or a set of values) is set for a keypath (or a set of keypaths) for the first time.
    created is an object with the new keypaths as keys and their corresponding values as values
    Note: a new create event will be emitted when the value for a keypath is deleted (set to undefined) and the reset to a value
    Note: a matching update event will also be emitted for each create event

  • update(< object >updated)
    Emitted when a value (or a set of values) is changed for a keypath (or a set of keypaths).
    updated is an object with the updated keypaths as keys and corresponding values as values
    Note: an update event will be emitted even if there is no previous value for the keypath

  • delete(< object >deleted)
    Emitted when a value (or a set of values) is deleted (or set to undefined) for a keypath (or a set of keypaths).
    deleted is an object with the deleted keypaths as keys and corresponding values as values
    Note: a matching update event will also be emitted for each delete event