博客
关于我
你不知道的--save-dev和--save的区别
阅读量:526 次
发布时间:2019-03-07

本文共 1678 字,大约阅读时间需要 5 分钟。

在项目开发过程中,npm包的存储位置和依赖管理是一个需要注意的重点。开发者常常会遇到关于-save-dev-save以及devDependenciesdependencies之间区别的疑惑。本文将通过实际操作和测试,帮助开发者更好地理解这些概念。

1. npm依赖存储的基本原理

npm在安装依赖时,默认会将软件包存储在node_modules目录下。这里需要注意-save-dev-save两种命令的区别:

  • -save-S:会将依赖项添加到dependencies中,默认作为线上依赖。

  • -save-dev-D:会将依赖项添加到devDependencies中,仅在开发环境中使用。

2. 实际操作中的表现

为了更直观地了解这些命令的实际效果,我进行了以下实验:

  • 安装jQuery:在项目根目录下执行npm install jquery,jQuery会被安装在node_modules中,但不会被添加到package.json中的任何依赖项中,除非后续使用-save-save-dev

    npm install jqueryls node_modules

    此时,node_modules中会出现jquery文件夹,但package.json中没有记录此依赖。

  • 使用-save命令:为了将jQuery作为线上依赖添加到项目中,可以执行:

    npm install jquery --save

    因此,package.json中的dependencies中会有"jquery": "^x.x.x",同时node_modules中也会保留jquery

  • 使用-save-dev命令:将jQuery作为开发依赖添加:

    npm install jquery --save-dev

    此时,package.json中的devDependencies中会有"jquery": "^x.x.x"node_modules同样会保留jquery

3. 不同依赖级别的打包表现

在最终打包生成main.js文件时,无论依赖项是在dependencies还是devDependencies中,都会被包含进打包结果。即使未使用--save--save-dev命令,依赖项仍能通过node_modules找到。

4. 含external依赖的情况

当引入带有外部依赖的库(如axios)时,可以观察以下情况:

  • 安装axios

    npm install axios
    • node_modules中会出现axios和相关依赖。
    • packages.json中没有明确记录这些依赖项。

5. 依赖冲突与解决方案

为了防止依赖冲突,许多开发者会将基本包裹放在dependencies中,而高级包裹放在devDependencies中,或者使用peerDependencies来强制需求不在项目中。

例如,Bootstrap并不直接将其依赖项添加到dependencies中,而是将它们作为peerDependencies

"peerDependencies": {  "jquery": "1.9.1 - 3",  "popper.js": "^1.16.0"}

这意味着在安装Bootstrap时,会强制下载并安装这些依赖项,但不会将它们添加到项目中,从而避免版本冲突。

结论

  • -save:将依赖项添加到dependencies中,适用于线上使用。
  • -save-dev:将依赖项添加到devDependencies,仅在开发环境中使用。
  • devDependenciesdependencies:二者可以同时存在,具体取决于项目需求。
  • 打包效果:无论依赖项在dependencies还是devDependencies中,打包结果都会包含这些依赖项。
  • 发布第三方包:为了避免依赖冲突,建议使用peerDependencies或谨慎管理外部依赖版本。

在实践中,选择合适的依赖级别不仅影响开发工作流程,也会对包的大小和打包性能产生影响。因此,清晰地记录依赖关系是项目管理中的重要环节。

转载地址:http://uxnnz.baihongyu.com/

你可能感兴趣的文章
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置binlog_使用处理器抓取binlog数据_实际操作01---大数据之Nifi工作笔记0040
查看>>
NIFI从MySql中增量同步数据_通过Mysql的binlog功能_实时同步mysql数据_配置数据路由_实现数据插入数据到目标数据库_实际操作03---大数据之Nifi工作笔记0042
查看>>
NIFI同步MySql数据_到SqlServer_错误_驱动程序无法通过使用安全套接字层(SSL)加密与SQL Server_Navicat连接SqlServer---大数据之Nifi工作笔记0047
查看>>
Nifi同步过程中报错create_time字段找不到_实际目标表和源表中没有这个字段---大数据之Nifi工作笔记0066
查看>>
NIFI大数据进阶_离线同步MySql数据到HDFS_02_实际操作_splitjson处理器_puthdfs处理器_querydatabasetable处理器---大数据之Nifi工作笔记0030
查看>>
NIFI大数据进阶_连接与关系_设置数据流负载均衡_设置背压_设置展现弯曲_介绍以及实际操作---大数据之Nifi工作笔记0027
查看>>
NIFI数据库同步_多表_特定表同时同步_实际操作_MySqlToMysql_可推广到其他数据库_Postgresql_Hbase_SqlServer等----大数据之Nifi工作笔记0053
查看>>
NIFI汉化_替换logo_二次开发_Idea编译NIFI最新源码_详细过程记录_全解析_Maven编译NIFI避坑指南001---大数据之Nifi工作笔记0068
查看>>
NIFI集群_内存溢出_CPU占用100%修复_GC overhead limit exceeded_NIFI: out of memory error ---大数据之Nifi工作笔记0017
查看>>
NIFI集群_队列Queue中数据无法清空_清除队列数据报错_无法删除queue_解决_集群中机器交替重启删除---大数据之Nifi工作笔记0061
查看>>
NIH发布包含10600张CT图像数据库 为AI算法测试铺路
查看>>
Nim教程【十二】
查看>>
Nim游戏
查看>>
NIO ByteBuffer实现原理
查看>>
Nio ByteBuffer组件读写指针切换原理与常用方法
查看>>
NIO Selector实现原理
查看>>
nio 中channel和buffer的基本使用
查看>>
NIO基于UDP协议的网络编程
查看>>
NISP一级,NISP二级报考说明,零基础入门到精通,收藏这篇就够了
查看>>
Nitrux 3.8 发布!性能全面提升,带来非凡体验
查看>>