使用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 相关文章推荐
function foo的原型与prototype属性解惑
Nov 19 Javascript
基于datagrid框架的查询
Apr 08 Javascript
jQuery文件上传插件Uploadify使用指南
Jun 05 Javascript
jquery实现多屏多图焦点图切换特效的方法
May 04 Javascript
javascript跨域总结之window.name实现的跨域数据传输
Nov 01 Javascript
AngularJs Understanding the Model Component
Sep 02 Javascript
AngularJS使用ng-Cloak阻止初始化闪烁问题的方法
Nov 03 Javascript
Javarscript中模块(module)、加载(load)与捆绑(bundle)详解
May 28 Javascript
原生js实现简单的模态框示例
Sep 08 Javascript
node.js 核心http模块,起一个服务器,返回一个页面的实例
Sep 11 Javascript
小程序实现列表多个批量倒计时
Jan 29 Javascript
详解Vue后台管理系统开发日常总结(组件PageHeader)
Nov 01 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
PHP写的加密函数,支持私人密钥(详细介绍)
2013/06/09 PHP
PHP实现字符串翻转功能的方法【递归与循环算法】
2017/11/03 PHP
javascript在事件监听方面的兼容性小结
2010/04/07 Javascript
jquery 学习笔记一
2010/04/07 Javascript
js 幻灯片的实现
2011/12/06 Javascript
jQuery之自动完成组件的深入解析
2013/06/19 Javascript
15条JavaScript最佳实践小结
2013/08/09 Javascript
JS获取下拉列表所选中的TEXT和Value的实现代码
2014/01/11 Javascript
jquery判断元素是否隐藏的多种方法
2014/05/06 Javascript
js限制文本框只能输入数字方法小结
2014/06/16 Javascript
jquery实现图片左右切换的方法
2015/05/07 Javascript
BootStrap栅格系统、表单样式与按钮样式源码解析
2017/01/20 Javascript
利用JS实现简单的瀑布流加载图片效果
2017/04/22 Javascript
JQuery EasyUI 结合ztrIee的后台页面开发实例
2017/09/01 jQuery
JS实现前端页面的搜索功能
2018/06/12 Javascript
微信小程序视图容器(swiper)组件创建轮播图
2020/06/19 Javascript
es6 filter() 数组过滤方法总结
2019/04/03 Javascript
JS实现马赛克图片效果完整示例
2019/04/13 Javascript
vue+elementUI动态增加表单项并添加验证的代码详解
2020/12/17 Vue.js
使用Python编写基于DHT协议的BT资源爬虫
2016/03/19 Python
python中的内置函数max()和min()及mas()函数的高级用法
2018/03/29 Python
[原创]windows下Anaconda的安装与配置正解(Anaconda入门教程)
2018/04/05 Python
python print 按逗号或空格分隔的方法
2018/05/02 Python
Python中Numpy包的安装与使用方法简明教程
2018/07/03 Python
python中dict使用方法详解
2019/07/17 Python
python爬虫项目设置一个中断重连的程序的实现
2019/07/26 Python
pytorch实现线性拟合方式
2020/01/15 Python
深入了解python列表(LIST)
2020/06/08 Python
css3动画效果抖动解决方法
2018/09/03 HTML / CSS
一套带网友答案的.NET笔试题
2016/12/06 面试题
JavaScript实现前端网页版倒计时
2021/03/24 Javascript
幼儿园教师求职信
2015/03/20 职场文书
2015年社区统计工作总结
2015/04/21 职场文书
傲慢与偏见电影观后感
2015/06/10 职场文书
Python实战之实现康威生命游戏
2021/04/26 Python
Python实现列表拼接和去重的三种方式
2021/07/02 Python