使用nvm管理不同版本的node与npm的方法


Posted in Javascript onOctober 31, 2017

本文介绍了使用 nvm 管理不同版本的 node 与 npm ,分享给大家,具体如下:

补充说明:Mac 下通过 brew install nvm 所安装的 nvm ,由于安装路径不同,无法正确启用。建议使用 brew uninstall nvm 卸载掉之后,通过本文的方案重新安装一次。

最近 NodeJS 的版本更新速度有点 Chrome 的迹象,4.0 版本没发布多久,又推出了 5.0 。升级 NodeJS 之后可以很方便的开始使用一些 ES6 的语言特性,但又会导致团队内部的mz-fis 框架无法更新,因为它暂时只支持 v0.12 版本。于是团队开始试用管理 node 版本的工具  nvm,试用后发现 Mac 下很好用,推荐大家尽快用起来。

nvm 是 Mac 下的 node 管理工具,有点类似管理 Ruby 的 rvm,如果是需要管理 Windows 下的 node,官方推荐是使用 nvmw 或nvm-windows 。

以下具体说下 Mac 系统中的安装与使用细节(Windows 系统仅供类比参考)。

一、卸载已安装到全局的 node/npm

如果之前是在官网下载的 node 安装包,运行后会自动安装在全局目录,其中

node 命令在 /usr/local/bin/node ,npm 命令在全局 node_modules 目录中,具体路径为 /usr/local/lib/node_modules/npm

安装 nvm 之后最好先删除下已安装的 node 和全局 node 模块:

npm ls -g --depth=0 #查看已经安装在全局的模块,以便删除这些全局模块后再按照不同的 node 版本重新进行全局安装

sudo rm -rf /usr/local/lib/node_modules #删除全局 node_modules 目录
sudo rm /usr/local/bin/node #删除 node
cd /usr/local/bin && ls -l | grep "../lib/node_modules/" | awk '{print $9}'| xargs rm #删除全局 node 模块注册的软链

二、安装 nvm

curl -o- https://raw.githubusercontent.com/creationix/nvm/v0.29.0/install.sh | bash

安装完成后请重新打开终端环境,Mac 下推荐使用oh-my-zsh 代替默认的 bash shell。

三、安装切换各版本 node/npm

nvm install stable #安装最新稳定版 node,现在是 5.0.0
nvm install 4.2.2 #安装 4.2.2 版本
nvm install 0.12.7 #安装 0.12.7 版本

# 特别说明:以下模块安装仅供演示说明,并非必须安装模块
nvm use 0 #切换至 0.12.7 版本
npm install -g mz-fis #安装 mz-fis 模块至全局目录,安装完成的路径是 /Users/<你的用户名>/.nvm/versions/node/v0.12.7/lib/mz-fis
nvm use 4 #切换至 4.2.2 版本
npm install -g react-native-cli #安装 react-native-cli 模块至全局目录,安装完成的路径是 /Users/<你的用户名>/.nvm/versions/node/v4.2.2/lib/react-native-cli

nvm alias default 0.12.7 #设置默认 node 版本为 0.12.7

四、使用 .nvmrc 文件配置项目所使用的 node 版本

如果你的默认 node 版本(通过 nvm alias 命令设置的)与项目所需的版本不同,则可在项目根目录或其任意父级目录中创建 .nvmrc 文件,在文件中指定使用的 node 版本号,例如:

cd <项目根目录> #进入项目根目录
echo 4 > .nvmrc #添加 .nvmrc 文件
nvm use #无需指定版本号,会自动使用 .nvmrc 文件中配置的版本
node -v #查看 node 是否切换为对应版本

五、nvm 与 n 的区别

node 版本管理工具还有一个是 TJ 大神的 n 命令,n 命令是作为一个 node 的模块而存在,而 nvm 是一个独立于 node/npm 的外部 shell 脚本,因此 n 命令相比 nvm 更加局限。

由于 npm 安装的模块路径均为 /usr/local/lib/node_modules ,当使用 n 切换不同的 node 版本时,实际上会共用全局的 node/npm 目录。 因此不能很好的满足『按不同 node 版本使用不同全局 node 模块』的需求。

因此建议各位尽早开始使用 nvm ,以免出现全局模块无法更新的问题。

当然,如果你用的是 windows 操作系统,我只能说 …… 朋友,能不能早点换个 Mac ,做一个有品位的程序猿呢:P

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JS中简单的实现像C#中using功能(有源码下载)
Jan 09 Javascript
Array, Array Constructor, for in loop, typeof, instanceOf
Sep 13 Javascript
js获取当前页面路径示例讲解
Jan 08 Javascript
jQuery事件之键盘事件(ctrl+Enter回车键提交表单等)
May 11 Javascript
JavaScript将Web页面内容导出到Word及Excel的方法
Feb 13 Javascript
jquery插件jSignature实现手动签名
May 04 Javascript
javascript字符串与数组转换汇总
May 26 Javascript
js 实现省市区三级联动菜单效果
Feb 20 Javascript
基于AGS JS开发自定义贴图图层
Mar 31 Javascript
AngularJS 控制器 controller的详解
Oct 17 Javascript
jQuery中实现text()的方法
Apr 04 jQuery
解决父组件将子组件作为弹窗调用只执行一次created的问题
Jul 24 Javascript
javascript高级模块化require.js的具体使用方法
Oct 31 #Javascript
JS简单实现点击跳转登陆邮箱功能的方法
Oct 31 #Javascript
jQuery简单实现对数组去重及排序操作实例
Oct 31 #jQuery
Node.js学习教程之HTTP/2服务器推送【译】
Oct 31 #Javascript
详解Vue用自定义指令完成一个下拉菜单(select组件)
Oct 31 #Javascript
原生js实现仿window10系统日历效果的实例
Oct 31 #Javascript
ES6使用Set数据结构实现数组的交集、并集、差集功能示例
Oct 31 #Javascript
You might like
thinkphp四种url访问方式详解
2014/11/28 PHP
PHP静态延迟绑定和普通静态效率的对比
2017/10/20 PHP
Laravel-添加后台模板AdminLte的实现方法
2019/10/08 PHP
php实现快速对二维数组某一列进行组装的方法小结
2019/12/04 PHP
javascript模拟的Ping效果代码 (Web Ping)
2011/03/13 Javascript
JS判断元素为数字的奇异写法分享
2012/08/01 Javascript
JavaScript中访问节点对象的方法有哪些如何使用
2013/09/24 Javascript
JSON无限折叠菜单编写实例
2013/12/16 Javascript
60个很实用的jQuery代码开发技巧收集
2014/12/15 Javascript
jquery实现多条件筛选特效代码分享
2015/08/28 Javascript
JS判断元素是否在数组内的实现代码
2016/03/30 Javascript
javascript HTML5 canvas实现打砖块游戏
2020/06/18 Javascript
Javascript iframe交互并兼容各种浏览器的解决方法
2016/07/12 Javascript
JavaScript 数组- Array的方法总结(推荐)
2016/07/21 Javascript
jquery checkbox无法用attr()二次勾选问题的解决方法
2016/07/22 Javascript
zepto与jquery的区别及zepto的不同使用8条小结
2016/07/28 Javascript
完美实现js焦点轮播效果(一)
2017/03/07 Javascript
javascript实现table单元格点击展开隐藏效果(实例代码)
2017/04/10 Javascript
原生JS实现自定义滚动条效果
2020/10/27 Javascript
AngularJS 的$timeout服务示例代码
2017/09/21 Javascript
解决layui中的form表单与button的点击事件冲突问题
2018/08/15 Javascript
Jquery的Ajax技术使用方法
2019/01/21 jQuery
js设计模式之代理模式及订阅发布模式实例详解
2019/08/15 Javascript
Layui数据表格判断编辑输入的值,是否为我需要的类型详解
2019/10/26 Javascript
Js利用正则表达式去除字符串的中括号
2020/11/23 Javascript
Python实现发送email的几种常用方法
2014/08/18 Python
python实现自动发送邮件
2018/06/20 Python
python pandas消除空值和空格以及 Nan数据替换方法
2018/10/30 Python
解决python中0x80072ee2错误的方法
2020/07/19 Python
怎么解决pycharm license Acti的方法
2020/10/28 Python
Rosetta Stone官方网站:语言学习
2019/01/05 全球购物
宿舍违规检讨书
2014/01/12 职场文书
《草原》教学反思
2014/02/15 职场文书
音乐教师个人总结
2015/02/06 职场文书
2016新年致辞
2015/08/01 职场文书
JavaScript设计模式之原型模式详情
2022/06/21 Javascript