Frequently Asked Questions
Where can I find these docs in HTML?
https://npmjs.org/doc/, or run:
npm config set viewer browser
to open these documents in your default web browser rather than
It didn't work.
That's not really a question.
Why didn't it work?
I don't know yet.
Read the error output, and if you can't figure out what it means, do what it says and post a bug with all the information it asks for.
Where does npm put stuff?
- Use the
npm rootcommand to see where modules go, and the
npm bincommand to see where executables go
- Global installs are different from local installs. If
you install something with the
-gflag, then its executables go in
npm bin -gand its modules go in
npm root -g.
How do I install something on my computer in a central location?
Install it globally by tacking
to the command. (This is especially important for command line
utilities that need to add their bins to the global system
I installed something globally, but I can't
Install it locally.
The global install location is a place for command-line
utilities to put their bins in the system
. It's not for use with
a module in your code, then that means it's a dependency,
and a part of your program. You need to install it locally in
Why can't npm just put everything in one place, like other package managers?
Not every change is an improvement, but every improvement is a change. This would be like asking git to do network IO for every commit. It's not going to happen, because it's a terrible idea that causes more problems than it solves.
It is much harder to avoid dependency conflicts without nesting
dependencies. This is fundamental to the way that npm works, and
has proven to be an extremely successful approach. See
for more details.
If you want a package to be installed in one place, and have all
your programs reference the same copy of it, then use the
command. That's what it's for. Install it globally, then
link it into each program that uses it.
Whatever, I really want the old style 'everything global' style.
Write your own package manager, then. It's not that hard.
npm will not help you do something that is known to be a bad idea.
Should I check my
folder into git?
Mikeal Rogers answered this question very well:
node_modulesinto git for things you deploy, such as websites and apps.
- Do not check
node_modulesinto git for libraries and modules intended to be reused.
- Use npm to manage dependencies in your dev environment, but not in your deployment scripts.
Is it 'npm' or 'NPM' or 'Npm'?
npm should never be capitalized unless it is being displayed in a location that is customarily all-caps (such as the title of man pages.)
If 'npm' is an acronym, why is it never capitalized?
Contrary to the belief of many, "npm" is not in fact an abbreviation for "Node Package Manager". It is a recursive bacronymic abbreviation for "npm is not an acronym". (If it was "ninaa", then it would be an acronym, and thus incorrectly named.)
"NPM", however, is an acronym (more precisely, a capitonym) for the National Association of Pastoral Musicians. You can learn more about them at http://npm.org/.
In software, "NPM" is a Non-Parametric Mapping utility written by Chris Rorden. You can analyze pictures of brains with it. Learn more about the (capitalized) NPM program at http://www.cabiatl.com/mricro/npm/.
The first seed that eventually grew into this flower was a bash
utility named "pm", which was a shortened descendent
of "pkgmakeinst", a bash function that was used to
install various different things on different platforms, most
often using Yahoo's
was ever an acronym for anything, it was
So, in all seriousness, the "npm" project is named
after its command-line utility, which was organically selected
to be easily typed by a right-handed programmer using a US
QWERTY keyboard layout, ending with the right-ring-finger in a
postition to type the
key for flags and other command-line arguments. That
command-line utility is always lower-case, though it starts most
sentences it is a part of.
How do I list installed packages?
How do I search for packages?
Arguments are greps.
npm search jsdom
shows jsdom packages.
How do I update npm?
npm update npm -g
You can also update all outdated local packages by doing
without any arguments, or global packages by doing
npm update -g
Occasionally, the version of npm will progress such that the
current version cannot be properly installed with the version
that you have installed already. (Consider, if there is ever a
bug in the
In those cases, you can do this:
curl https://npmjs.org/install.sh | sh
What is a
A package is:
- a) a folder containing a program described by a package.json file
- b) a gzipped tarball containing (a)
- c) a url that resolves to (b)
- d) a
<name>@<version>that is published on the registry with (c)
- e) a
<name>@<tag>that points to (d)
- f) a
<name>that has a "latest" tag satisfying (e)
- g) a
giturl that, when cloned, results in (a).
Even if you never publish your package, you can still get a lot of benefits of using npm if you just want to write a node program (a), and perhaps if you also want to be able to easily install it elsewhere after packing it up into a tarball (b).
Git urls can be of the form:
git://github.com/user/project.git#commit-ish git+ssh://user@hostname:project.git#commit-ish git+http://user@hostname/project/blah.git#commit-ish git+https://user@hostname/project/blah.git#commit-ish
can be any tag, sha, or branch which can be supplied as an
. The default is
What is a
A module is anything that can be loaded with
in a Node.js program. The following things are all examples of
things that can be loaded as modules:
- A folder with a
package.jsonfile containing a
- A folder with an
index.jsfile in it.
Most npm packages are modules, because they are libraries that
you load with
. However, there's no requirement that an npm package be a
module! Some only contain an executable command-line interface,
and don't provide a
field for use in Node programs.
Almost all npm packages (at least, those that are Node programs)
contain many modules within them (because every file
they load with
is a module).
In the context of a Node program, the
is also the thing that was loaded from a file. For
example, in the following program:
var req = require('request')
we might say that "The variable
refers to the
So, why is it the "
" folder, but "
" file? Why not
file defines the package. (See "What is a package?"
folder is the place Node.js looks for modules. (See "What
is a module?" above.)
For example, if you create a file at
and then had a program that did
var f = require('foo.js')
then it would load the module. However,
is not a "package" in this case, because it does not
have a package.json.
Alternatively, if you create a package which does not have an
field in the
file, then it is not a module. Even if it's installed in
, it can't be an argument to
is the name of my deity's arch-rival, and a Forbidden Word
in my religion. Can I configure npm to use a different folder?
No. This will never happen. This question comes up sometimes, because it seems silly from the outside that npm couldn't just be configured to put stuff somewhere else, and then npm could load them from there. It's an arbitrary spelling choice, right? What's the big deal?
At the time of this writing, the string
appears 151 times in 53 separate files in npm and node core
(excluding tests and documentation).
Some of these references are in node's built-in module loader. Since npm is not involved at all at run-time, node itself would have to be configured to know where you've decided to stick stuff. Complexity hurdle #1. Since the Node module system is locked, this cannot be changed, and is enough to kill this request. But I'll continue, in deference to your deity's delicate feelings regarding spelling.
Many of the others are in dependencies that npm uses, which are
not necessarily tightly coupled to npm (in the sense that they
do not read npm's configuration files, etc.) Each of these
would have to be configured to take the name of the
folder as a parameter. Complexity hurdle #2.
Furthermore, npm has the ability to "bundle"
dependencies by adding the dep names to the
list in package.json, which causes the folder to be included in
the package tarball. What if the author of a module bundles its
dependencies, and they use a different spelling for
? npm would have to rename the folder at publish time, and then
be smart enough to unpack it using your locally configured name.
Complexity hurdle #3.
Furthermore, what happens when you change this name?
Fine, it's easy enough the first time, just rename the
or whatever name you choose. But what about when you change it
again? npm doesn't currently track any state about past
configuration settings, so this would be rather difficult to do
properly. It would have to track every previous value for this
config, and always accept any of them, or else yesterday's
install may be broken tomorrow. Complexity hurdle #5.
Never going to happen. The folder is named
. It is written indelibly in the Node Way, handed down from the
ancient times of Node 0.3.
How do I install node with npm?
You don't. Try one of these node version managers:
How can I use npm for development?
You'll most likely want to
your development folder. That's awesomely handy.
To set up your own private registry, check out
Can I list a url as a dependency?
Yes. It should be a url to a gzipped tarball containing a single folder that has a package.json in its root, or a git url. (See "what is a package?" above.)
How do I symlink to a dev folder so I don't have to keep re-installing?
The package registry website. What is that exactly?
I forgot my password, and can't publish. How do I reset it?
Go to https://npmjs.org/forgot.
I get ECONNREFUSED a lot. What's up?
Either the registry is down, or node's DNS isn't able to reach out.
To check if the registry is down, open up http://registry.npmjs.org/ in a web browser. This will also tell you if you are just unable to access the internet for some reason.
Why no namespaces?
Please see this discussion: https://github.com/isaacs/npm/issues/798
tl;dr - It doesn't actually make things better, and can make them worse.
If you want to namespace your own packages, you may: simply use
character to separate the names. npm is a mostly anarchic
system. There is not sufficient need to impose namespace rules
Who does npm?
npm view npm author
npm view npm contributors
I have a question or request not addressed here. Where should I put it?
Post an issue on the github project:
Why does npm hate me?
npm is not capable of hatred. It loves everyone, especially you.