How to install npm packages from GitHub

npm packages are usually installed from the npm registry located in registry.npmjs.org.

You can perform a package installation using the npm install command like this:

npm install lodash

But the registry is not the only source for installing packages.

According to the npm install documentation, a package can be a folder containing a JavaScript project that has a package.json file as its description.

npm can also install from a Git remote URL, as long as the target has a package.json file in the root directory.

For example, you can install the same lodash package from its GitHub homepage as follows:

npm install https://github.com/lodash/lodash

npm will look into the package.json file located in the root project and install the lodash package from the GitHub URL above.

You can also choose to install a specific branch by defining the /tree/{branch} in your URL.

The example below installs express version 4.18 from its GitHub URL:

npm install https://github.com/expressjs/express/tree/4.18

You can also install a specific commit by replacing the {branch} with the {commit} hash like this:

npm install https://github.com/axios/axios/tree/934f390cc3

The packages you installed using GitHub URLs will be listed as dependencies with the following URI format:

github:{username}/{repo}
#or
github:{username}/{repo}#{branch}
#or
github:{username}/{repo}#{commit}

Here’s an example of the dependencies list in the package.json file:

{
  "dependencies": {
    "axios": "github:axios/axios#934f390cc3",
    "express": "github:expressjs/express#4.18",
    "lodash": "github:lodash/lodash"
  }
}

When you didn’t mention a specific branch or commit, then the installation will proceed using the default branch (generally main or master branch)

You can also use the GitHub URI to install packages from GitHub:

npm install github:axios/axios

The URI github:axios/axios will resolve to https://github.com/axios/axios URL and install the axios package for you.

Installing from a GitHub private repository

You can install a package from a GitHub private repository as long as you have access to the repo as an authenticated user.

For example, I can install packages from my private repository as follows:

npm install https://github.com/nsebhastian/private-package

The repository URL above is a private repo, but because I’m an authenticated user, I can access my own repos.

If you have an SSH key set up for your GitHub user or organization, you can also use the SSH URL to install the package:

npm install git@github.com:nsebhastian/private-package.git

And that’s how you install packages from GitHub private repos.

Conclusion

Although you can install packages available from GitHub, installing from the npm registry should always be your first choice.

This is because the npm registry provides you with packages in tarball format, compressing the package size to allow faster download time.

The npm registry also stores all available versions that you can get with the npm view {package} versions command:

$ npm view axios versions
[
  '0.1.0',  '0.2.0',  '0.2.1',         '0.2.2',
  '0.3.0',  '0.3.1',  '0.4.0',         '0.4.1',
  '0.4.2',  '0.5.0',  '0.5.1',         '0.5.2',
  '0.5.3',  '0.5.4',  '0.6.0',         '0.7.0',
  '0.8.0',  '0.8.1',  '0.9.0',         '0.9.1',
  '0.10.0', '0.11.0', '0.11.1',        '0.12.0',
  '0.13.0', '0.13.1', '0.14.0',        '0.15.0',
  '0.15.1', '0.15.2', '0.15.3',        '0.16.0',
  '0.16.1', '0.16.2', '0.17.0',        '0.17.1',
  '0.18.0', '0.18.1', '0.19.0-beta.1', '0.19.0',
  '0.19.1', '0.19.2', '0.20.0-0',      '0.20.0',
  '0.21.0', '0.21.1', '0.21.2',        '0.21.3',
  '0.21.4', '0.22.0', '0.23.0',        '0.24.0',
  '0.25.0', '0.26.0', '0.26.1',        '0.27.0',
  '0.27.1', '0.27.2'
]

Instead of rolling back to a specific branch or commit, you can roll back to the previous release versions, which is safer for production builds.

Finally, packages installed from GitHub will be skipped when you run the npm outdated command, so you can’t check for the latest version.

But if your package is a private package, then installing from Github may be a viable alternative. You need a paid user account to publish private packages to npm registry.

Now you’ve learned how to install npm packages from GitHub URLs. Good work! 👍

Take your skills to the next level ⚡️

I'm sending out an occasional email with the latest tutorials on programming, web development, and statistics. Drop your email in the box below and I'll send new stuff straight into your inbox!

No spam. Unsubscribe anytime.