mirror of https://github.com/nodejs/node.git
109 lines
3.3 KiB
Groff
109 lines
3.3 KiB
Groff
.TH "NPM\-SCOPE" "7" "September 2014" "" ""
|
|
.SH "NAME"
|
|
\fBnpm-scope\fR \- Scoped packages
|
|
.SH DESCRIPTION
|
|
.P
|
|
All npm packages have a name\. Some package names also have a scope\. A scope
|
|
follows the usual rules for package names (url\-safe characters, no leading dots
|
|
or underscores)\. When used in package names, preceded by an @\-symbol and
|
|
followed by a slash, e\.g\.
|
|
.P
|
|
.RS 2
|
|
.EX
|
|
@somescope/somepackagename
|
|
.EE
|
|
.RE
|
|
.P
|
|
Scopes are a way of grouping related packages together, and also affect a few
|
|
things about the way npm treats the package\.
|
|
.P
|
|
\fBAs of 2014\-09\-03, scoped packages are not supported by the public npm registry\fR\|\.
|
|
However, the npm client is backwards\-compatible with un\-scoped registries, so
|
|
it can be used to work with scoped and un\-scoped registries at the same time\.
|
|
.SH Installing scoped packages
|
|
.P
|
|
Scoped packages are installed to a sub\-folder of the regular installation
|
|
folder, e\.g\. if your other packages are installed in \fBnode_modules/packagename\fR,
|
|
scoped modules will be in \fBnode_modules/@myorg/packagename\fR\|\. The scope folder
|
|
(\fB@myorg\fR) is simply the name of the scope preceded by an @\-symbol, and can
|
|
contain any number of scoped packages\.
|
|
.P
|
|
A scoped package is install by referencing it by name, preceded by an @\-symbol,
|
|
in \fBnpm install\fR:
|
|
.P
|
|
.RS 2
|
|
.EX
|
|
npm install @myorg/mypackage
|
|
.EE
|
|
.RE
|
|
.P
|
|
Or in \fBpackage\.json\fR:
|
|
.P
|
|
.RS 2
|
|
.EX
|
|
"dependencies": {
|
|
"@myorg/mypackage": "^1\.3\.0"
|
|
}
|
|
.EE
|
|
.RE
|
|
.P
|
|
Note that if the @\-symbol is omitted in either case npm will instead attempt to
|
|
install from GitHub; see npm help \fBnpm\-install\fR\|\.
|
|
.SH Requiring scoped packages
|
|
.P
|
|
Because scoped packages are installed into a scope folder, you have to
|
|
include the name of the scope when requiring them in your code, e\.g\.
|
|
.P
|
|
.RS 2
|
|
.EX
|
|
require('@myorg/mypackage')
|
|
.EE
|
|
.RE
|
|
.P
|
|
There is nothing special about the way Node treats scope folders, this is
|
|
just specifying to require the module \fBmypackage\fR in the folder called \fB@myorg\fR\|\.
|
|
.SH Publishing scoped packages
|
|
.P
|
|
Scoped packages can be published to any registry that supports them\.
|
|
\fIAs of 2014\-09\-03, the public npm registry does not support scoped packages\fR,
|
|
so attempting to publish a scoped package to the registry will fail unless
|
|
you have associated that scope with a different registry, see below\.
|
|
.SH Associating a scope with a registry
|
|
.P
|
|
Scopes can be associated with a separate registry\. This allows you to
|
|
seamlessly use a mix of packages from the public npm registry and one or more
|
|
private registries, such as npm Enterprise\.
|
|
.P
|
|
You can associate a scope with a registry at login, e\.g\.
|
|
.P
|
|
.RS 2
|
|
.EX
|
|
npm login \-\-registry=http://reg\.example\.com \-\-scope=@myco
|
|
.EE
|
|
.RE
|
|
.P
|
|
Scopes have a many\-to\-one relationship with registries: one registry can
|
|
host multiple scopes, but a scope only ever points to one registry\.
|
|
.P
|
|
You can also associate a scope with a registry using \fBnpm config\fR:
|
|
.P
|
|
.RS 2
|
|
.EX
|
|
npm config set @myco:registry http://reg\.example\.com
|
|
.EE
|
|
.RE
|
|
.P
|
|
Once a scope is associated with a registry, any \fBnpm install\fR for a package
|
|
with that scope will request packages from that registry instead\. Any
|
|
\fBnpm publish\fR for a package name that contains the scope will be published to
|
|
that registry instead\.
|
|
.SH SEE ALSO
|
|
.RS 0
|
|
.IP \(bu 2
|
|
npm help install
|
|
.IP \(bu 2
|
|
npm help publish
|
|
|
|
.RE
|
|
|