【那些年踩过的坑-前端篇- Mac版本】Mac 从零搭建 Node 环境:nvm + Node + Vue 实战(避坑终极版)

📌 前言:为什么要这么折腾?

很多教程告诉你 curl | bash一把梭,但在国内网络环境 + Mac 新架构(M 系列芯片)下,这往往会遇到:

  • raw.githubusercontent.com连不上
  • nvm ls-remote无输出或输出 HTML
  • ❌ Node 装好了但 npm 全局包冲突
  • ❌ zsh 报 insecure directories

本文基于 nvm 官方 GitHub READMEinstall.sh 脚本逻辑 ,结合实战踩坑,给出一套 100% 可复现的安装方案


一、核心原理(Dan Koe 系统思维)

在开始之前,理解这三个东西的关系至关重要:

组件 作用 官方推荐
nvm Node 版本管理器 官方推荐
Node.js JavaScript 运行时 通过 nvm 安装
npm 包管理器 随 Node 自带

核心原则

  1. 不要直接安装 Node:避免系统级权限污染。
  2. 不要使用 sudo npm install:nvm 的精髓在于用户级隔离。
  3. 国内必须配置镜像:这是成功的关键。

二、Step 1:安装 nvm(从 0 开始)

✅ 前置检查

确保你有 git:

复制代码
git --version

如果没有,先安装 Xcode Command Line Tools:

复制代码
xcode-select --install

✅ 坑 1:官方脚本下载失败(国内高频)

❌ 不推荐(国内常失败)

复制代码
curl -o- https://raw.githubusercontent.com/nvm-sh/nvm/v0.40.4/install.sh | bash

✅ 正确方案:Git Clone(官方支持)

根据 install.sh逻辑,如果 curl失败,应使用 git安装:

复制代码
git clone https://github.com/nvm-sh/nvm.git ~/.nvm
cd ~/.nvm
git checkout v0.40.4

✅ 坑 2:脚本未自动写入 Shell(手动补全 nvm 初始化)

有时 install.sh会因为权限或网络问题 没有自动修改你的 Shell 配置文件。你需要手动补全。

  1. 打开你的 Shell 配置文件(Mac 默认是 zsh):

    复制代码
    open -e ~/.zshrc

    如果文件不存在:

    复制代码
    touch ~/.zshrc
  2. 添加以下内容(这是 nvm 的灵魂)

    复制代码
    export NVM_DIR="$HOME/.nvm"
    [ -s "$NVM_DIR/nvm.sh" ] && \. "$NVM_DIR/nvm.sh" # This loads nvm
    [ -s "$NVM_DIR/bash_completion" ] && \. "$NVM_DIR/bash_completion" # This loads nvm bash_completion
  3. 使配置生效

    复制代码
    source ~/.zshrc

✅ 验证 nvm 是否安装成功

复制代码
command -v nvm

✅ 正确输出:nvm


三、Step 2:配置国内镜像(解决 Node 版本查询 & 下载)

✅ 坑 3:nvm ls-remote无输出或输出 HTML

如果你执行 nvm ls-remote --lts出现 空白,或者出现:

复制代码
This is not the package you are looking for

这是因为 GitHub / Node 官方源被拦截。

根据 README 中的 Environment variables 说明,我们需要设置镜像。

✅ 解决方案:配置 Node 国内镜像

复制代码
export NVM_NODEJS_ORG_MIRROR=https://npmmirror.com/mirrors/node

永久生效(强烈推荐)

复制代码
echo 'export NVM_NODEJS_ORG_MIRROR=https://npmmirror.com/mirrors/node' >> ~/.zshrc
source ~/.zshrc

✅ 配置 npm 国内镜像(加速依赖下载)

复制代码
npm config set registry https://registry.npmmirror.com

四、Step 3:使用 nvm 安装 & 验证 Node

✅ 安装 Node LTS(推荐)

复制代码
nvm install --lts

✅ 设置默认版本

复制代码
nvm alias default lts/*
nvm use --lts

✅ 完整验证

复制代码
node -v  # 应显示 v20.x.x 或更高
npm -v
nvm ls   # 应显示当前使用的 Node 版本

正确状态node的路径应包含 .nvm,例如:

复制代码
/Users/你的用户名/.nvm/versions/node/v20.18.0/bin/node

五、Step 4:创建并运行 Vue 项目

✅ 创建 Vue 项目

复制代码
npm create vite@latest my-vue-app -- --template vue
cd my-vue-app

✅ 安装依赖并启动

复制代码
rm -rf node_modules package-lock.json # 养成好习惯,确保干净安装
npm install
npm run dev

✅ 浏览器访问 http://localhost:5173,看到 Vue 欢迎页即成功。


六、常见"坑"单独标注(排雷区)

⚠️ 坑 4:.npmrc导致 nvm 冲突

现象

复制代码
Your user's .npmrc file has a `globalconfig` and/or a `prefix` setting, which are incompatible with nvm.

解决

复制代码
nvm use --delete-prefix v24.16.0 --silent

或者手动删除 ~/.npmrc中的 prefixglobalconfig配置。


⚠️ 坑 5:zsh insecure directories

现象

复制代码
zsh compinit: insecure directories

原因 :Homebrew 或手动修改导致 /usr/local/share/zsh权限过松。

解决

复制代码
sudo chown -R $(whoami):staff /usr/local/share/zsh
chmod -R u+rwx,go-w,go+rX /usr/local/share/zsh

⚠️ 坑 6:Node 版本号不存在

现象

复制代码
Version '20.19.0' not found

原因 :Vite 提示的是 major.minor 要求,并非完整版本号。

解决 :使用 nvm install --lts或查询 nvm ls-remote找真实存在的 patch 版本(如 20.18.0)。


七、总结

  1. 安装 nvm :放弃 curl | bash,使用 git clone更稳定。
  2. 初始化 nvm :若脚本未自动写入,务必手动补全 ~/.zshrc
  3. 国内镜像 :必须配置 NVM_NODEJS_ORG_MIRROR和 npm registry。
  4. Node 管理 :始终使用 nvm installnvm use

按照这套流程,你的 Mac 将拥有一个 干净、隔离、可随时切换版本 的 Node 开发环境,足以应对 Vue等各种复杂实战场景。


如果这篇文章解决了你的环境难题,请不要吝啬你的 👍 (点赞) 和 ⭐ (收藏)!

有任何环境搭建的疑问,欢迎在评论区留言交流。


相关推荐
iccb101318 小时前
5年,一个程序员是如何把私有化在线客服系统做到第一名的
前端·后端·github
假如让我当三天老蒯18 小时前
回归基本功:Map/Set 与 WeakMap/WeakSet 的区别
前端·面试
IT乐手18 小时前
48队都装不下你|国足第24次让全世界失望
前端
SoaringHeart19 小时前
Flutter最佳实践:IM聊天文字链接自动识别跳转
前端·flutter
掘金一周20 小时前
企业中要做智能体,最佳的方案是什么? | 沸点周刊 6.18
前端·人工智能·ai编程
Darling噜啦啦20 小时前
CSS 3D 变换与 Flex 布局实战:从零打造旋转立方体
前端·css
秃头网友小李20 小时前
前端难点:keep-alive 缓存什么?RouterView 的 key 为什么要带 scopeId?
前端·vue.js
鱼人20 小时前
CSS 变量:一个变量救你一百次复制粘贴
前端
长大198820 小时前
CSS 到底是什么?和 HTML 的区别一次讲清楚
前端
禅思院20 小时前
路由性能优化终极指南:从懒加载漏洞到边缘渲染的架构跃迁
前端·架构·前端框架