npm通过github url来安装私有库

背景

有时候我们想要安装的node Package是来自我们自己开发的二方包,但是对于个人开发者来说,也许我们没有私有的npm registry。这时我们可以通过自己私库的github url来用npm安装二方包。

方法

请注意,通过github url安装的前提是project里有package.json。

  1. 通过npm cli安装github public project
javascript 复制代码
npm i https://github.com/user_name/node_project_name

也可以通过如下方式安装具体的某个commit:

shell 复制代码
npm install use_name/node_project#commit

安装branch:

shell 复制代码
npm install use_name/node_project#branchName

通过tag或者version来安装

shell 复制代码
npm install use_name/node_project@tag #user_name/node_project@release
npm install use_name/node_project@version #user_name/node_project@1.0.0
  1. 安装私库
    私库的安装需要使用git的ssh repo link:
shell 复制代码
npm install git+ssh://git@github.com:user_name/node_project.git

二方包导出

Node.js 支持 用于在 package.json 中定义入口点的新字段,称为 "exports"。该字段是在 package.json 中定义 "main" 的更强大的替代方法,并且可以控制您的包的哪些部分暴露给引用者。

这是一个支持 CommonJS 和 ESM 的单独入口点的 package.json:

Here's an package.json that supports separate entry-points for CommonJS and ESM:

javascript 复制代码
// package.json
{
    "name": "my-package",
    "type": "module",
    "exports": {
        ".": {
            // Entry-point for `import "my-package"` in ESM
            "import": "./esm/index.js",

            // Entry-point for `require("my-package") in CJS
            "require": "./commonjs/index.cjs",
        },
    },

    // CJS fall-back for older versions of Node.js
    "main": "./commonjs/index.cjs",
}
相关推荐
程序猿online29 分钟前
nvm安装使用,控制node版本
开发语言·前端·学习
web Rookie39 分钟前
React 中 createContext 和 useContext 的深度应用与优化实战
前端·javascript·react.js
男孩1243 分钟前
react高阶组件及hooks
前端·javascript·react.js
m0_748251721 小时前
DataOps驱动数据集成创新:Apache DolphinScheduler & SeaTunnel on Amazon Web Services
前端·apache
珊珊来吃1 小时前
EXCEL中给某一列数据加上双引号
java·前端·excel
onejason1 小时前
深度解析:利用Python爬虫获取亚马逊商品详情
前端·python
胡西风_foxww2 小时前
【ES6复习笔记】Spread 扩展运算符(8)
前端·笔记·es6·扩展·运算符·spread
小林爱2 小时前
【Compose multiplatform教程08】【组件】Text组件
android·java·前端·ui·前端框架·kotlin·android studio
跨境商城搭建开发2 小时前
一个服务器可以搭建几个网站?搭建一个网站的流程介绍
运维·服务器·前端·vue.js·mysql·npm·php
hhzz2 小时前
vue前端项目中实现电子签名功能(附完整源码)
前端·javascript·vue.js