我有一个下载的模块repo,我想在本地安装它,而不是全局安装在另一个目录?

有什么简单的方法吗?


当前回答

来自npm-link文档:

在本地模块目录下:

$ cd ./package-dir
$ npm link

在项目的目录下使用模块:

$ cd ./project-dir
$ npm link package-name

或者一次性使用相对路径:

$ cd ./project-dir
$ npm link ../package-dir

这相当于在上面使用两个命令。

其他回答

对于npm的最新版本(我在macOS Big Sur下使用8.1.3),命令序列甚至更容易…

cd /path-where-your-local-project-is/
npm init

这将要求您提供一些与项目相关的数据,并正确初始化您的项目。json文件。

一旦完成,你可以安装额外的模块:

cd /path-where-your-local-project-is/
npm install --save-dev some-npm-module .

这就是你所需要的!

注意:我相信如果你在项目目录中,后面的点是不必要的,但我也认为添加它没有坏处:-)

(我想知道为什么官方文件仍然没有解释这一点…)

NPM pack + package.json

这对我来说很管用:

步骤1:在模块项目中,执行npm pack:

这将构建一个<package-name>-<version>.tar.gz文件。

步骤2:将文件移动到使用者项目

理想情况下,你可以把所有这些文件放在你的消费者-项目根目录下的tmp文件夹中:

步骤3:在package.json中引用它:

"dependencies": {
  "my-package": "file:/./tmp/my-package-1.3.3.tar.gz"
}

第四步:安装包:

NPM安装或NPM I或纱线

现在,您的包可以在您的消费者项目的node_modules文件夹中使用。

祝你好运…

我遇到了不同的解决方案,而不是上面安装自定义构建包ckedor5。

所以我上传包到应用程序根目录,比:

npm add file:./ckeditor5

在我的包裹里。Json包被列为一个文件:

"ckeditor5-custom-build": "file:ckeditor5",

我认为这个答案可能与如何添加本地包的主题相关。

由于由同一个人提问和回答,我将添加一个npm链接作为替代。

从文档:

这对于安装您自己的东西非常方便,这样您就可以使用它并迭代地测试它,而不必不断地重新构建。

cd ~/projects/node-bloggy  # go into the dir of your main project
npm link ../node-redis     # link the dir of your dependency

[编辑]从NPM 2.0开始,你可以在package.json中声明本地依赖项

"dependencies": {
    "bar": "file:../foo/bar"
  }

用于安装尚未在npm上安装的本地模块/包,或者你正在开发一个npm包,并希望在发布之前在本地测试它。你可以试试这个

npm i yalc -g

转到模块/包文件夹,然后-

yalc publish

您的软件包已经可以使用了,现在进入您想要安装它的项目-

yalc add <Your package name>

包将安装到您的项目。如果你想移除它-

yalc remove <Your package name>