- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我读自here如果人们通过 npm 安装您的项目,则 package.json 文件中的依赖项允许人们安装依赖项-
Finally, the dependencies field is used to list all the dependencies of your project that are available on npm. When someone installs your project through npm, all the dependencies listed will be installed as well. Additionally, if someone runs npm install in the root directory of your project, it will install all the dependencies to ./node_modules.
如果有人不在你项目的根目录下运行 npm install,所有的依赖会被安装到哪里?
此外,如果他们选择通过 Github 克隆该项目怎么办?无论如何它都准备好了,对吧?那么 package.json 文件除了为用户提供有关项目的元数据之外还有什么用途?
最佳答案
Where will all the dependencies be installed to if someone doesn't run npm install in the root directory of your project?
如果你的意思是“如果你在不同的目录中运行命令,它们将安装在哪里”,NPM 将向上搜索父目录,直到找到 package.json
,然后安装该文件旁边的 node_modules
文件夹中的依赖项。 IE。它们将始终位于项目根目录中。
Also, what if they choose to clone this project through Github instead? It would be ready to go anyway, right? Then at that point what is the purpose of the package.json file besides giving the user meta data about the project?
不是这样的! Node 项目几乎总是有一个 .gitignore
文件,它明确地将 node_modules
排除在版本控制之外,并期望你在之后运行 npm install
下载源代码。
将依赖项放在 GitHub 存储库中的理由很少——只要项目符合 Semantic Versioning 即可。 (绝大多数包都是这样做的),npm install
永远不会导致下载不兼容的版本,如果你绝对需要锁定依赖项的版本,你可以只使用 npm shrinkwrap
.
编辑:正如 Matt 的评论非常有帮助地指出的那样,NPM 有几个超越简单元数据的功能 - 我可能最常使用的功能是 Scripts ,它允许您为命令行操作创建特定于项目的别名。
这对我有用的一个例子是运行 Webpack 开发服务器 - 它在 devDependencies
中本地安装到我的项目(你可以使用 --save -dev
option when installing a package), 所以如果我手动进行,我将不得不输入以下内容:
"./node_modules/.bin/webpack-dev-server" --inline --hot
坦率地说,这会有点痛苦。相反,我可以将它添加到我的 package.json(注意 node_modules/.bin
在使用 NPM 脚本时会自动添加到系统路径,所以你不需要每次都输入它):
"scripts": {
"dev": "webpack-dev-server --inline --hot"
}
然后我要做的就是:
npm run dev
除了这个简单的用例之外,还有几个“特殊”脚本名称,它们会在某些事件发生时自动调用 - 例如,prepublish
在将包发布到注册表之前运行。
关于node.js - NPM package.json 文件的主要用途是什么?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36230289/
最近开始学习MongoDB。今天老师教了我们 mongoexport 命令。在练习时,我遇到了一个典型的问题,包括教练在内的其他同学都没有遇到过。我在我的 Windows 10 机器上使用 Mongo
我是 JSON Schema 的新手,读过什么是 JSON Schema 等等。但我不知道如何将 JSON Schema 链接到 JSON 以针对该 JSON Schema 进行验证。谁能解释一下?
在 xml 中,我可以在另一个 xml 文件中包含一个文件并使用它。如果您的软件从 xml 获取配置文件但没有任何方法来分离配置,如 apache/ngnix(nginx.conf - site-av
我有一个 JSON 对象,其中包含一个本身是 JSON 对象的字符串。我如何反序列化它? 我希望能够做类似的事情: #[derive(Deserialize)] struct B { c: S
考虑以下 JSON { "a": "{\"b\": 12, \"c\": \"test\"}" } 我想定义一个泛型读取 Reads[Outer[T]]对于这种序列化的 Json import
关闭。这个问题不满足Stack Overflow guidelines .它目前不接受答案。 想改善这个问题吗?更新问题,使其成为 on-topic对于堆栈溢出。 11 个月前关闭。 Improve
我的旧项目在 MySQL 中有 Standard JSON 格式的数据。 对于我在 JS (Node.js) 和 DynamoDB 中的全新项目,关于 Standard JSON格式: 是否建议将其转
JSON 值字符串、数字、true、false、null 是否是有效的 JSON? 即,是 true 一个有效的 JSON 文档?还是必须是数组/对象? 一些验证器接受这个(例如 http://jso
我有一个 JSON 字符串,其中一个字段是文本字段。这个文本字段可以包含用户在 UI 中输入的文本,如果他们输入的文本是 JSON 文本,也许是为了说明一些编码,我需要对他们的文本进行编码,以便它不会
我正在通过 IBM MQ 调用处理数据,当由 ColdFusion 10 (10,0,11,285437) 序列化时,0 将作为 +0.0 返回,它会导致无效的 JSON并且无法反序列化。 stPol
我正在从三个数组中生成一个散列,然后尝试构建一个 json。我通过 json object has array 成功了。 require 'json' A = [['A1', 'A2', 'A3'],
我从 API 接收 JSON,响应可以是 30 种类型之一。每种类型都有一组唯一的字段,但所有响应都有一个字段 type 说明它是哪种类型。 我的方法是使用serde .我为每种响应类型创建一个结构并
我正在下载一个 JSON 文件,我已将其检查为带有“https://jsonlint.com”的有效 JSON 到文档目录。然后我打开文件并再次检查,结果显示为无效的 JSON。这怎么可能????这是
我正在尝试根据从 API 接收到的数据动态创建一个 JSON 对象。 收到的示例数据:将数据解码到下面给出的 CiItems 结构中 { "class_name": "test", "
我想从字符串转换为对象。 来自 {"key1": "{\n \"key2\": \"value2\",\n \"key3\": {\n \"key4\": \"value4\"\n }\n
目前我正在使用以下代码将嵌套的 json 转换为扁平化的 json: import ( "fmt" "github.com/nytlabs/gojsonexplode" ) func
我有一个使用来自第三方 API 的数据的应用程序。我需要将 json 解码为一个结构,这需要该结构具有“传入”json 字段的 json 标签。传出的 json 字段具有不同的命名约定,因此我需要不同
我想使用 JSON 架构来验证某些值。我有两个对象,称它们为 trackedItems 和 trackedItemGroups。 trackedItemGroups 是组名称和 trackedItem
考虑以下案例类模式, case class Y (a: String, b: String) case class X (dummy: String, b: Y) 字段b是可选的,我的一些数据集没有字
我正在存储 cat ~/path/to/file/blah | 的输出jq tojson 在一个变量中,稍后在带有 JSON 内容的 curl POST 中使用。它运作良好,但它删除了所有换行符。我知
我是一名优秀的程序员,十分优秀!