mac npm install XX权限权限报错的完美解决方法(修改npm全局安装包的位置,解决EACCES权限拒绝问题)

简介

​ 在macOS系统下,npm默认的全局安装路径是在/usr/local/lib/node_modules下。例如:当我们执行npm i -g vue-cli时,实际上是把vue-cli这个模块安装到了/usr/local/lib/node_modules目录下了。

​ ⚠️注意: /usr/local/lib这个是系统目录,会有权限问题,虽然可以使用sudo执行,但是还是有部分机器,即使使用root用户执行npm i -g xxx 全局安装某个模块还是会出现EACCES permissions权限被拒绝问题。

​ ?解决办法: 通过修改npm全局安装模块的路径解决,将npm全局安装模块的路径,修改到当前登陆用户的HOME目录下即可,这样用不用sudo都不会出现EACCES permissions权限被拒绝问题了。

​ ⚠️️注意:本教程不适合Windows系统

操作

0、查看当前npm的默认配置

npm config ls

1、在你的用户主目录下创建.npm-global文件夹作为npm全局安装的目录

mkdir ~/.npm-global

2、修改npm使用新的全局安装路径

npm config set prefix '~/.npm-global'

3、修改PATH环境变量

vim ~/.bash_profile //编辑.bash_profile文件,这个文件是用户登陆终端的时候会自动执行的文件

4、在~/.bash_profile文件添加下面这行代码

export PATH=~/.npm-global/bin:$PATH

 

mac npm install XX权限权限报错的完美解决方法(修改npm全局安装包的位置,解决EACCES权限拒绝问题)_第1张图片

5、更新系统变量,获取重启命令行终端

source ~/.bash_profile

6、测试配置,在不使用sodu的情况下全局安装一个包

npm install -g mocha

 

​ 可以看到此后全局安装的模块都被安装到了~/.npm-global目录下了

总结

​ 其实解决全局安装模块权限不足问题的方法:主要是将npm全局安装模块的目录修改到了用户的主目录下,这样用户不需要sodu也能够全局安装模块,因为它是在自己的主目录下操作,永远不会存在权限问题。

你可能感兴趣的:(前端体系)