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

definitely

v1.0.15

Published

Disallow undefined property access in JavaScript

Downloads

35

Readme

definitely Build Status

Find undefined property bugs close to the source.

Installation

$ npm install --save-dev definitely

Usage and rationale

JavaScript allows you to access nonexistent properties on an object and simply evaluates the expression to undefined. Usually when this happens it's a bug, but since no error is thrown such bugs can be a difficult to debug as the problem tends to rear its ugly head far from whence it came. For example,

const obj = {
  foo: 'bar'
}

someFunction(obj.bar)

obj has no property bar, so we're passing undefined to someFunction, which may pass it to another function, put it onto a queue, etc. It could be much later and in a completely different area of the code when someone tries to do something they shouldn't with that undefined value, at which point we'll begin the laborious process of trying to figure out where things went awry.

That's where definitely comes in:

import definitely from 'definitely'

const definiteObj = definitely({
  foo: 'bar'
})

someFunction(definiteObj.bar) // throws "Error: attempted to access nonexistent property `bar`"

Now you've caught the bug right at the source!

Note

The magic that enables this library is an ES2015 feature called Proxy, which allows intercepting arbitrary property access attempts and deciding what to do with them (in our case we throw an exception if the underlying object is missing the requisite property). Proxy is not yet supported in all browsers (e.g. IE and Safari) and in Node prior to version 6 requires a special flag (--harmony-proxies) and shim. If Proxy is not found in the global scope, this library becomes a no-op.

See also

definitely-loader, a Webpack loader which verifies that imported names exist within the target module.