如何指定本地模块作为npm包依赖

我有一个应用程序,它对第三方模块有通常的依赖集(例如。'express')。Json文件下的依赖。如。

"express"     : "3.1.1"

我想模块化地构造我自己的代码,并有一组本地(意思是我目前在的文件系统上)模块被package.json安装。我知道我可以通过运行以下命令来安装本地模块:

npm install path/to/mymodule

但是,我不知道如何通过包来实现这一点。Json依赖结构。在这个命令中使用--save选项只是将"mymodule": "0.0.0"放入我的包中。Json(不引用文件路径位置)。如果我从node_modules中删除已安装的版本,并尝试从包中重新安装。Json,它会失败(因为它寻找"mymodule"在中央注册表中,而不是在本地查找)。

我确信这是一种告诉"dependencies": {}结构的方式,我希望它从文件系统路径安装,但不知道如何安装。

其他人有这个问题吗? 谢谢。< / p >
428020 次浏览

如果你可以简单地发布你在node_modules中预安装的模块和其他文件,你可以这样做:

// ./node_modules/foo/package.json
{
"name":"foo",
"version":"0.0.1",
"main":"index.js"
}


// ./package.json
...
"dependencies": {
"foo":"0.0.1",
"bar":"*"
}


// ./app.js
var foo = require('foo');

你可能还想把你的模块存储在git上,然后告诉你的父包。https://npmjs.org/doc/json.html#Git-URLs-as-Dependencies . json来安装git的依赖项

最后我找不到一个简洁的方法,所以我去创建一个名为local_modules的目录,然后将这个bashscript添加到包中。脚本中的Json ->preinstall

#!/bin/sh
for i in $(find ./local_modules -type d -maxdepth 1) ; do
packageJson="${i}/package.json"
if [ -f "${packageJson}" ]; then
echo "installing ${i}..."
npm install "${i}"
fi
done

npm install现在支持这个

npm install --save ../path/to/mymodule

为此,必须将mymodule配置为具有自己的package.json的模块。看到创建NodeJS模块

从npm 2.0开始,本地依赖项在本地得到支持。看到Danilopopeye对类似问题的回答。我在这里复制了他的回答,因为这个问题在网络搜索结果中排名非常高。

该特性在npm 2.0.0版本中实现。例如:

{
"name": "baz",
"dependencies": {
"bar": "file:../foo/bar"
}
}

以下任何路径都是有效的:

../foo/bar
~/foo/bar
./foo/bar
/foo/bar

同步更新

由于npm install <folder>将包作为符号链接添加到当前项目的目录中,因此对本地包的任何更改都会自动同步。

在与npm link命令(开发本地模块而不将它们发布到注册表或在node_modules文件夹中维护一个单独的副本的建议解决方案)进行了大量的斗争之后,我构建了一个小的npm模块来帮助解决这个问题。

修复需要两个简单的步骤

第一:

npm install lib-manager --save-dev

其次,将其添加到package.json:

{
"name": "yourModuleName",
// ...
"scripts": {
"postinstall": "./node_modules/.bin/local-link"
}
}

更多细节在https://www.npmjs.com/package/lib-manager。希望它能帮助到别人。

在工作中,我们有一个公共库,在一个存储库中由几个不同的项目使用。最初我们使用的是已发布的(私有)版本(npm install—save rp-utils),但在开发过程中,这导致了许多不必要的版本更新。库位于应用程序的姐妹目录中,我们可以使用相对路径而不是版本。而不是"rp-utils": "^1.3.34"在包中。Json现在是:

{
"dependencies": { ...
"rp-utils": "../rp-utils",
...

rp-utils目录包含一个可发布的NPM包

你可以把它加到你的套餐里。Json文件在您的项目

"package-name" : "path/to/package"

然后在你的项目中运行npm i

使用安装本地

我遇到了来自本地依赖的冲突反应安装的问题。 我通过使用install-local npm包解决了这个错误。这个包不创建符号链接,这解决了我的问题

步骤:

  1. 运行npm i -g install-local
  2. 在目标存储库中运行npx install-local --save <local-path>来安装本地依赖项

进一步阅读:https://www.npmjs.com/package/install-local

当我试图用npm install --save <local-directory>安装本地包时,我收到的错误:

错误:无效的钩子调用。钩子只能在函数组件的内部调用。这可能是由于以下原因之一:

  1. React和渲染器的版本可能不匹配(比如React DOM)
  2. 你可能违反了胡克斯的规矩
  3. 你可能在同一个应用程序中有多个React副本