The JSPM CLI is the main command-line import map package management tool for JSPM.
For a complete guide and introduction to the JSPM CLI and import map package management, see the getting started guide.
For import map generation API usage or in other environments, see the low-level Generator API which is the internal import map package management and generation API which this CLI project wraps. The Generator API documentation also provides a more thorough details of the operations.
The following command installs JSPM globally:
npm install -g jspm
For a full list of commands and supported options, run jspm --help
. For help with a specific command, add the -h
or --help
flag to the command invocation.
By default, JSPM operates on importmap.json
which is automatically created if it does not exist. This is considered the main import map on which link and install operations are being performed, and can be customized with the --map
option.
jspm link [flags] [...modules]
Traces and installs all dependencies necessary to execute the given modules into an import map, including both static and dynamic module imports. The given modules can be:
- Paths to local JavaScript modules, such as "./src/my-module.mjs".
- Paths to local HTML files, such as "index.html", in which case all module scripts in the file are linked.
- Valid package specifiers, such as
react
or[email protected]
, in which case the package's main export is linked. - Valid package specifiers with subpaths, such as
[email protected]/convert-range
, in which case the subpath is resolved against the package's exports and the resulting module is linked.
In some cases there may be ambiguity. For instance, you may want to link the NPM package "app.js", but your working directory contains a local file called "app.js" as well. In these cases local files are preferred by default, and external packages must be prefixed with the "%" character (i.e. "%app.js").
If no modules are given, all "imports" in the initial map are relinked.
-m, --map
<file> File containing initial import map (default: importmap.json)-o, --output
<file> File to inject the final import map into (default: --map / importmap.json)-e, --env
<environments> Comma-separated environment condition overrides-r, --resolution
<resolutions> Comma-separated dependency resolution overrides-p, --provider
<providers> Default module provider. Available providers: jspm.io, nodemodules, deno, jsdelivr, skypack, unpkg, esm.sh, jspm.io#system--cache
<mode> Cache mode for fetches (online, offline, no-cache) (default: online)--root
<url> URL to treat as server root, i.e. rebase import maps against--preload
[mode] Add module preloads to HTML output (default: static, dynamic)--integrity
Add module preloads with integrity attributes to HTML output (default: false)--compact
Output a compact import map (default: false)--freeze
Freeze input map dependencies, i.e. do not modify them (default: false)--stdout
Output the import map to stdout (default: false)--silent
Silence all output (default: false)-h, --help
Display this message
Link a remote package in importmap.json
jspm link [email protected]
Link a local module
jspm link ./src/cli.js
Link an HTML file and update its import map including preload and integrity tags
jspm link --map index.html --integrity --preload dynamic
jspm install [flags] [...packages]
Installs packages into an import map, along with all of the dependencies that are necessary to import them.By default, the latest versions of the packages that are compatible with the local "package.json" are installed, unless an explicit version is specified. The given packages must be valid package specifiers, such as npm:[email protected]
or denoland:oak
. If a package specifier with no registry is given, such as lit
, the registry is assumed to be NPM. Packages can be installed under an alias by using specifiers such as myname=npm:[email protected]
. An optional subpath can be provided, such as npm:[email protected]/decorators.js
, in which case only the dependencies for that subpath are installed.
If no packages are provided, all "imports" in the initial map are reinstalled.
-m, --map
<file> File containing initial import map (default: importmap.json)-o, --output
<file> File to inject the final import map into (default: --map / importmap.json)-e, --env
<environments> Comma-separated environment condition overrides-r, --resolution
<resolutions> Comma-separated dependency resolution overrides-p, --provider
<providers> Default module provider. Available providers: jspm.io, nodemodules, deno, jsdelivr, skypack, unpkg, esm.sh, jspm.io#system--cache
<mode> Cache mode for fetches (online, offline, no-cache) (default: online)--root
<url> URL to treat as server root, i.e. rebase import maps against--preload
[mode] Add module preloads to HTML output (default: static, dynamic)--integrity
Add module preloads with integrity attributes to HTML output (default: false)--compact
Output a compact import map (default: false)--freeze
Freeze input map dependencies, i.e. do not modify them (default: false)--stdout
Output the import map to stdout (default: false)--silent
Silence all output (default: false)-h, --help
Display this message
Install a package
jspm install lit
Install a versioned package and subpath
jspm install npm:[email protected]/decorators.js
Install a versioned package
jspm install npm:[email protected]
Install a Denoland package and use the Deno provider
jspm install -p deno denoload:oak
Install "alias" as an alias of the resolution react
jspm install alias=react
jspm uninstall [flags] [...packages]
Uninstalls packages from an import map. The given packages must be valid package specifiers, such as npm:[email protected]
, denoland:oak
or lit
, and must be present in the initial import map.
-m, --map
<file> File containing initial import map (default: importmap.json)-o, --output
<file> File to inject the final import map into (default: --map / importmap.json)-e, --env
<environments> Comma-separated environment condition overrides-r, --resolution
<resolutions> Comma-separated dependency resolution overrides-p, --provider
<providers> Default module provider. Available providers: jspm.io, nodemodules, deno, jsdelivr, skypack, unpkg, esm.sh, jspm.io#system--cache
<mode> Cache mode for fetches (online, offline, no-cache) (default: online)--root
<url> URL to treat as server root, i.e. rebase import maps against--preload
[mode] Add module preloads to HTML output (default: static, dynamic)--integrity
Add module preloads with integrity attributes to HTML output (default: false)--compact
Output a compact import map (default: false)--freeze
Freeze input map dependencies, i.e. do not modify them (default: false)--stdout
Output the import map to stdout (default: false)--silent
Silence all output (default: false)-h, --help
Display this message
jspm uninstall lit lodash
Uninstall "lit" and "lodash" from importmap.json.
jspm update [flags] [...packages]
Updates packages in an import map to the latest versions that are compatible with the local package.json
. The given packages must be valid package specifiers, such as npm:[email protected]
, denoland:oak
or lit
, and must be present in the initial import map.
-m, --map
<file> File containing initial import map (default: importmap.json)-o, --output
<file> File to inject the final import map into (default: --map / importmap.json)-e, --env
<environments> Comma-separated environment condition overrides-r, --resolution
<resolutions> Comma-separated dependency resolution overrides-p, --provider
<providers> Default module provider. Available providers: jspm.io, nodemodules, deno, jsdelivr, skypack, unpkg, esm.sh, jspm.io#system--cache
<mode> Cache mode for fetches (online, offline, no-cache) (default: online)--root
<url> URL to treat as server root, i.e. rebase import maps against--preload
[mode] Add module preloads to HTML output (default: static, dynamic)--integrity
Add module preloads with integrity attributes to HTML output (default: false)--compact
Output a compact import map (default: false)--freeze
Freeze input map dependencies, i.e. do not modify them (default: false)--stdout
Output the import map to stdout (default: false)--silent
Silence all output (default: false)-h, --help
Display this message
jspm update react-dom
Update the react-dom package.
jspm clear-cache
Clears the global module fetch cache, for situations where the contents of a dependency may have changed without a version bump. This can happen during local development, for instance.
--silent
Silence all output (default: false)-h, --help
Display this message
Environments allow for configuring the conditional resolutions (ie conditional exports and imports) for resolved packages.
The default environments for all operations are development
, browser
and module
.
To configure different environments, you can provide one or more -e
or --env
flags with additional environment names to resolve. Environments like development
and production
are modal, meaning that setting one will override the other. To disable the default browser
or module
environments, you can set the no-browser
or no-module
environments respectively.
The environments used to generate a particular import map are recorded in the resulting map, so specifying the environments for a series of operations is only necessary for the first one.
Compareing the import maps for axios
in a browser environment (the default), and a non-browser environment:
diff <(jspm i axios --stdout) <(jspm i axios -e no-browser --stdout)
[...]
< "#lib/adapters/http.js": "https://ga.jspm.io/npm:@jspm/[email protected]/nodelibs/@empty.js",
< "#lib/platform/node/classes/FormData.js": "https://ga.jspm.io/npm:@jspm/[email protected]/nodelibs/@empty.js",
< "#lib/platform/node/index.js": "https://ga.jspm.io/npm:@jspm/[email protected]/nodelibs/@empty.js"
---
> "#lib/": "https://ga.jspm.io/npm:[email protected]/lib/",
[...]
Providers are used to resolve package canonical names (such as npm:[email protected]
) to resolved URLs (such as https://ga.jspm.io/npm:[email protected]/). The default provider for all operations is jspm.io
, which uses the jspm.io CDN for package resolutions. To configure a different provider, you can provide a -p
or --provider
flag.
The following providers are supported:
jspm.io
jspm.io#system
nodemodules
esm.sh
unpkg
jsdelivr
Most of these providers will resolve against their corresponding CDNs. For instance, esm.sh
uses the esm.sh CDN, unpkg
uses the UNPKG CDN, and so on.
The jspm.io#system
provider also uses the jspm.io CDN, but the resolved packages use the SystemJS module format rather than ESM.
The nodemodules
provider resolves packages against the local node_modules
folder, allowing you to generate import maps for local development. This will only work in the browser if all dependencies are ESM dependencies.
jspm install -p nodemodules lit
Installs lit
into the import map using the nodemodules
provider, which maps packges against the local node_modules
directory. Note that this will fail unless lit
and its dependencies have already been installed locally with npm
. The resulting import map looks like this:
{
"env": [
"browser",
"development",
"module"
],
"imports": {
"lit": "./node_modules/lit/index.js"
},
"scopes": {
"./node_modules/": {
"@lit/reactive-element": "./node_modules/@lit/reactive-element/development/reactive-element.js",
"lit-element/lit-element.js": "./node_modules/lit-element/development/lit-element.js",
"lit-html": "./node_modules/lit-html/development/lit-html.js",
"lit-html/is-server.js": "./node_modules/lit-html/development/is-server.js"
}
}
}
Resolutions are used to remap package names to particular package targets. For instance, the latest version of one of your secondary dependencies may be broken, and you want to pin it to an older version, or even to a different package altogether. To do this, you can provide one or more -r
or --resolution
flags, with arguments [package_name]=[target_version]
or [package_name]=[registry]:[name]@[target-range]
. Package specifiers can take the full syntax described under jspm install
.
When a resolution is set, all dependencies on that package will take the given remapping, no matter what the the resolution context is. Note that this may cause packages to break in unexpected ways if you violate their dependency constraints.
jspm install react@latest -r react=npm:[email protected]
Installs npm:[email protected]
into the import map under the name react
. Note that this will happen even though we have specified a particular version for react
. The resulting import map looks like this:
{
"env": [
"browser",
"development",
"module"
],
"imports": {
"react": "https://ga.jspm.io/npm:[email protected]/dist/preact.module.js"
}
}
It is always recommended to generate modulepreload tags for production apps using import maps. This avoids the latency waterfall for dependency discovery by inlining preload hints for all statically loaded modules upfront.
In addition, preload tags can also include integrity attributes for static dependency integrity.
When performing HTML injection operations (ie when the --output
import map is an HTML file), --preload
and --integrity
can be used to handle this injection automatically.