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

strict-mode

v1.1.5

Published

enables strict mode in your package

Downloads

1,291

Readme

strict-mode

enables strict mode in your package

NPM version No deps JavaScript Style Guide

Installation

With npm do

npm install strict-mode --save-dev

NOTA BENE you may want to install strict-mode as a development dependency, see Bonus Tip below.

Usage

Please note that this package is intended to be used server side. If used with browserify it is a no op.

Suppose that the main attribute in your package.json is index.js. If you want that all the modules in your package have strict mode enabled, just wrap your index.js this way

require('strict-mode')(function () {

// your index.js content

// every *require* call inside this function will have strict mode enabled

})

Motivation

Strict mode is a best practice but adding a "use strict"; on top of every .js file in your package could

  • require a big effort
  • be error proning
  • make complain linters (like eslint, jshint, etc.)
  • be a problem when concatenating files

On the other hand the use-strict package solution is too invasive, cause it applies strictness to all future modules loaded.

Use case

At the time of this writing Node v4 stable version was released few days ago. Finally we can use class, let, const (among other new exciting features) but you will notice that if you do not turn on strict mode an exception will raise. For instance, a file Point2d.js with content

class Point2d {
  constructor (x, y) {
    this.x = x
    this.y = y
  }
}

module.exports = Point2d

when imported will complain

SyntaxError: Block-scoped declarations (let, const, function, class) not yet supported outside strict mode

but if you wrap the import with strict-mode everything will just work

require('strict-mode')(function () {

  var Point2d = require('./Point2d')
  // require all other classes you need.

  // You can also export them safely
  exports.Point2d = Point2d
})

Bonus tip

You could use strict-mode just as a development dependency.

Following the instructions below, you are not going to deploy strict-mode on production but when you run your tests if some code is not strict, then you will get an error.

Suppose you have the following folder structure in your package.

.
├── package.json
├── src
│   └── index.js    # your package.json `main` entry
└── test
    ├── test1.js
    └── test2.js

Assuming you package name is, emh my-package, create a file test/my-package.js containing

require('strict-mode')(function () {
  module.exports = require('../src/index.js')
})

Now if you set the environment variable NODE_PATH=test, you can use require('my-package') in your tests.

For instance if you are using tape you can add this to your package.json

    "test": "NODE_PATH=test tape test/*js"

You can also achieve the same result without NODE_PATH environment variable, using this nasty trick (to cheat npm :^) Instead of test/my-package.js, create a test/node_modules/my-package/index.js containing

require('strict-mode')(function () {
  module.exports = require('../../../src/index.js')
})

Notice also that you will probably need to force git add, for instance

git add -f test/node_modules/my-package/index.js

Credits

Code stolen from isaacs' use-strict. A big thank to MDN cause it is an awesome knowledge base for everything related with the Web: in particular, I could find some valid counterexamples of strict mode to include in my tests.

License

MIT