百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT知识 > 正文

一文搞定nodeJS相关的nvm、npm、nrm、yarn、npx等

liuian 2025-01-05 18:41 49 浏览

node、npm等相关概念

node 和 npm 相关的名词很多,比较容易混淆。

下面对这些名词做个统一梳理

  • node:一个基于 Chrome V8 引擎的 JavaScript 运行时;提供了 JavaScript 的运行环境。可以直接到 node 官网下载安装
  • nvm:node.js 版本管理工具;不同项目可能需要不同版本的 node;可以使用 nvm 来管理 node.js 版本
  • npm:node.js 包管理工具;用来管理 node.js 中的第三方插件;新版本的 node 在安装的时候,会自动安装对应版本的 npm
  • nrm:npm 源的管理工具,可以用来方便的切换 npm 源
  • cnpm:使用的是淘宝的源。用法跟 npm 完全一致。cnpm 经常会有问题,所以在很多地方不推荐使用
  • yarn:经过重新设计的崭新的 npm 客户端;运行速度显著提升,整个安装时间比 npm 少。一般推荐使用 yarn 代替 npm
  • npx:一个 npm 包执行器。我们可以使用 npx 来执行各种命令。

使用 nvm 管理 node.js 版本

参考:使用 nvm 管理 node.js 版本

npm

参考:npm常用命令操作

使用nrm管理npm源

当使用官方 npm 源安装各种包比较慢的时候,建议修改 npm 源地址

npm 相关参考:npm常用命令操作

推荐使用 nrm 管理 npm 源

nrm 是专门用来管理和快速切换私人配置的 registry

推荐全局安装

Bash
npm install nrm -g

常用命令

  • nrm ls :查看默认配置,带 * 号即为当前使用的配置
  • nrm current :查看当前使用的是哪个源
  • nrm use [源的别名] :切换到某个源
  • nrm add [源的别名] [源的地址] :添加私有源。eg: nrm add qihoo http://registry.npm.360.org
  • nrm test [源的别名] :测试某个源
  • nrm del [源的别名] :删除某个源

cnpm

npm 安装插件是从国外服务器下载,受网络影响大,可能出现异常。

淘宝团队复制了一个完成的 npmjs.org 镜像,用此代替官方版本(只读),同步频率目前为 10分钟 一次以保证尽量与官方服务同步。即: cnpm

cnpm 跟 npm 用法完全一致,只是在执行命令时将 npm 改为 cnpm

推荐全局安装cnpm

Bash
npm install -g cnpm --registry=https://registry.npm.taobao.org

安装完成后,可以使用命令 cnpm -v 检查是否安装成功。

如果能正常显示版本号,表示已安装成功。如果显示 不是内部或者外部命令 ,则需要手动将安装目录添加到系统变量中

yarn

yarn 是经过重新设计的崭新的 npm 客户端;运行速度显著提升,整个安装时间比 npm 少

像 npm 一样, yarn 使用本地缓存。与 npm 不同的是, yarn 无需互联网连接就能安装本地缓存的依赖项,它提供了离线模式。这个功能在2012年的 npm 项目中就被提出来过,但一直没有实现。

一般推荐使用 yarn 代替 npm

运行以下命令即可安装 yarn

npm install yarn -g

yarn 和 npm 命令对比如下

npm

yarn

描述

npm init

yarn init

初始化项目

npm install

yarn

yarn install

安装依赖

npm install xxx

npm install xxx --save

npm install xxx -S

yarn add xxx

安装某依赖,

写入dependencies

npm install xxx --save-dev

npm install xxx -D

yarn add xxx --dev

yarn add xxx -D

安装某依赖,

写入devDependencies

npm install xxx -g

yarn global add xxx

全局安装某依赖

npm update xxx

yarn upgrade xxx

更新某依赖

npm uninstall xxx

yarn remove xxx

删除某依赖

npm cache clean

yarn cache clean

清除全局缓存依赖包

npm run dev

yarn dev

yarn run dev

执行 dev 命令

npx

npx 是 npm v5.2.0 引入的一条命令( npx ),是一个 npm 包执行器。我们可以使用 npx 来执行各种命令。

主要有以下特点:

  • 临时安装可执行依赖包,不用全局安装,不用担心长期的污染。
  • 可以执行依赖包中的命令,安装完成自动运行。
  • 自动加载 node_modules 中依赖包,不用指定 $PATH
  • 可以指定 node 版本、命令的版本,解决了不同项目使用不同

npx 执行流程如下:

  • node_modules/.bin 路径检查对应的命令是否存在,找到之后执行;
  • 没有找到,就去环境变量 $PATH 里面,检查对应命令是否存在,找到之后执行;
  • 还是没有找到,自动下载一个临时的依赖包最新版本在一个临时目录,然后再运行命令,运行完之后删除,不污染全局环境。

安装过程很简单,直接运行以下命令即可

npm install npx -g

npx 使用场景

  • 执行本地命令

比如项目下安装了 mocha ,可以直接用 npx 执行

npx mocha --version
  • 一次性执行命令

比如以下命令,npx 将 create-react-app 下载到一个临时目录,使用以后再删除

不用全局安装 create-react-app ,运行后不会污染全局环境

npx create-react-app myApp
  • 切换 node 版本

要运行的命令不兼容当前的 node 版本时,可使用 npx 切换版

npx 的 -p 选项指定要安装的包,并将其添加到正在运行的 $PATH 中

npx node@12 -v
  • 开启静态服务器

使用 http-server 或者 serve 开启静态服务器。方便本地预览打包后的项目

npx http-server           # 默认返回根目录下index.html

npx http-server -p 3000   # 也可以直接指定端口

相关推荐

Python 内置GUI库Tkinter基本组件课程汇总

python现在是越来越火爆,已经渗入了各个行业。现在就连非软件开发人员都开始使用这个门语言来办公了。这门语言是最适合非研发人员学习的语言。平时我们最习惯用的就是双击电脑上的一个exe程序然后就运行程...

Python Tkinker GUI图形化代码生成

今天给大家分享一个好用的python小工具。面临编写tkinker代码时的繁琐,今天来用一个小工具帮助大家解决繁琐复杂的tkinker制作。效果展示上述图片就是最终效果了。程序中有各种按钮,控制器。可...

Python tkinter 学习笔记(一):父窗体和标签控件

‘Pythontkinter’是Python自带的GUI工具包,非常适合开发小型的GUI应用。最近使用‘tkinter’开发了一些自己日常使用的小工具,效果不错,于是把开发过程中学习到的一些’tki...

太实用了!自己动手写软件——GUI编程

这几天我有一个想法就是将我之前做测试写的一些协议脚本(如:ssh、FTP、SMTP、MySQL、Oracle等)综合在一起做一个密码破解器,这么多的协议放在一起,每个协议都有自己特殊的参数,如果还是和...

python入门到脱坑 输入与输出—input()函数

以下是针对Python初学者的input()函数完整指南,包含基础用法、安全注意事项和实用技巧:一、基础用法1.接收用户输入name=input("请输入你的名字:")#提...

用Python做个简单的登录页面(怎样用python制作登录界面)

我们上网时候,很多网站让你登录,没有账号注册会员,不能复制、粘贴都不让你操作。那我们怎么去实现这个窗口呢?很多语言都可以实现,根据你的需求去确定用哪个,这里我们学习python,就用tkinter测...

PyUIBuilder:用拖拽的方式轻松构建Python GUI

在快速发展的软件开发领域,图形用户界面(GUI)是用户与应用程序互动的主要方式。对于许多开发者而言,创建一个直观且美观的GUI常常需要耗费大量时间和精力。接下来介绍PyUIBuilder,一个开源项目...

Python实现语音识别与人脸识别技术结合,打造高效安全门禁系统。

目录前言一、实现步骤和雏形示例代码二、扩展思路介绍三、活体检测深度解读和示例代码四、人脸注册和管理示例代码五、实时监控和报警示例代码六、多因素认证示例代码七、访客管理示例代码八、数据加密和隐私保护示例...

Python | graphics、tkinter 画回归线

前言写Python题时遇到一道绘制回归线的题目。要求点击数据点输入进行绘制,我用graphics完成了。但是,这样输入并不精确,加上高中受到线性回归方程那庞大计算量的折磨,于是想写个能输数据的...

软件测试|超好用超简单的Python GUI库——tkinter(十四)

前言我们知道我们可以使用pillow绘制不同形状的图形,但是我们能不能使用tkinter实现这个功能呢,当然可以,tkinter也可以实现图形的绘制,并且可以将绘制的图形添加到我们的GUI中。我们可以...

Python 中使用 tkinter 模拟掷骰子

Python中有各种第三方库来设计图形用户界面。Tkinter是用于构建GUI图形用户界面应用程序的最流行、最常见、最易于使用的库。tkinter提供了一个强大的面向对象的界面,并且易于使用...

超级实用 Python GUI 入门(python做gui怎么样)

有时候使用python做自动化运维操作,开发一个简单的应用程序非常方便。程序写好,每次都要通过命令行运行python程序,就不是那么人性化了。为了更方便的操作,使用PythonGUI编写...

python可以做界面吗,怎么做(python可以写界面程序吗)

是的,Python可以用来开发图形用户界面(GUI)。Python提供了多种库和工具来创建界面,最常见的几个库包括:Tkinter:Python的标准GUI库,适用于小型应用程序,易于学习和...

Python GUI 编程:tkinter 初学者入门指南——Ttk 选项卡 Notebook

在本文中,将介绍如何使用TkinterNotebook小部件创建选项卡。Notebook是由TkinterTtk模块引入的强大小部件。允许开发者创建包含多个选项卡的界面,每个选项卡可以包...

Python,Tkinter的基础使用(python tkinter frame教程)

今天我们学习Python,Tkinter的基础使用。效果我们再加一点代码,就能显示出hitkinter这个内容。效果...