zoukankan      html  css  js  c++  java
  • npm ci命令解析

    一、用途

    npm ci和npm install命令一样,是用来安装依赖的命令,但他可以比常规的 npm 安装快得多,也比常规安装更严格,他可以npm依赖安装的一致和稳定 (锁版本)。

    在package.json中,每次install后,对应的版本前都有个 ^ 符号。在这种情况下,再次install时安装的包的版本可能与前次不一样,具体的,可以到package-lock.json中查看实际的包版本。

    ^的匹配规则是:>= 当前版本,且保持从左至右的第一个非零版本。举例说明:

    "^1.2.3": 大于等于 1.2.3 且小于 2.0.0版本
    "^0.3.4": 大于等于 0.3.4 且小于 0.4.0版本
    "^0.0.6": 大于等于 0.0.6 且小于 0.0.7版本

    若我们一直使用install命令时,便会遇到开发和测试、发布时包版本不同的问题,这种细微的差别往往会导致严重的结局。

    二、用法

    在npm i(install)的地方改用npm ci,当然项目中必须有一个package-lock.json或npm-shrinkwrap.json。

    注:npm版本要>=5.7。

    三、区别

    npm ci与npm i主要有以下的区别。

    • npm i依赖package.json,而npm ci依赖package-lock.json。
    • 当package-lock.json中的依赖于package.json不一致时,npm ci退出但不会修改package-lock.json。
    • npm ci只可以一次性的安装整个项目依赖,但无法添加单个依赖项。
    • npm ci安装包之前,会删除掉node_modules文件夹,因此他不需要去校验已下载文件版本与控制版本的关系,也不用校验是否存在最新版本的库,所以下载的速度更快。
    • npm安装时,不会修改package.json与package-lock.json。



      本文分享到这里,给朋友们推荐一个前端公众号 

  • 相关阅读:
    Qt/Qml 电子书阅读器
    Qt/Qml 翻页特效
    vue如何引入本地js(不被打包编译的js)文件
    CSS3解决移动端手指点击或滑动屏幕时出现的浅蓝色背景框
    vue移动端touch插件
    vue组件间通信六种方式(完整版)
    Vue 过渡实现轮播图
    vue中遇到的坑 --- 变化检测问题(数组相关)
    Vue判断设备是移动端还是pc端
    vue项目如何监听窗口变化,达到页面自适应?
  • 原文地址:https://www.cnblogs.com/cczlovexw/p/13206457.html
Copyright © 2011-2022 走看看