解决在 macOS 上终端找不到全局命令的问题

解决在 macOS 上终端找不到全局命令的问题

在 macOS 上,有时候我们会遇到全局安装的命令在终端中找不到的问题,例如 flutteryarn 等。通常这是因为这些工具的安装路径没有正确添加到 PATH 环境变量中。以下是解决这个问题的方法。

检查 Shell 配置文件

首先,确保你正在使用正确的 Shell(如 Zsh 或 Bash),并且 Shell 配置文件中包含必要的环境变量配置。

确认使用 Zsh

你可以运行以下命令检查当前使用的 Shell:

bash 复制代码
sh
复制代码
echo $SHELL

输出应该类似于 /bin/zsh/usr/bin/zsh。如果不是 Zsh,可以将其设置为默认 Shell:

bash 复制代码
sh
复制代码
chsh -s $(which zsh)

更新 ~/.zshrc 文件

确保 ~/.zshrc 文件中包含正确的配置。你可以使用以下命令打开并编辑 ~/.zshrc 文件:

bash 复制代码
sh
复制代码
nano ~/.zshrc

配置 nvm 和 Flutter

确保 nvm 和 Flutter 的路径已经添加到 ~/.zshrc 文件中:

bash 复制代码
sh
复制代码
# 设置 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

# 设置 Flutter
export PATH="$PATH:$HOME/flutter/bin"

配置 yarn

如果你已经全局安装了 yarn,但找不到命令,可能是 yarn 的安装路径没有正确添加到 PATH 环境变量中。

首先,确认 yarn 的安装路径:

bash 复制代码
sh
复制代码
which yarn

如果 which yarn 返回路径,比如 /usr/local/bin/yarn,说明 yarn 已经安装但可能没有在 PATH 中正确配置。

检查 npm 的全局安装路径:

arduino 复制代码
sh
复制代码
npm config get prefix

通常,yarn 会安装在这个路径的 bin 目录下,例如 /usr/local/bin/yarn

确保 ~/.zshrc 文件中包含以下内容:

bash 复制代码
sh
复制代码
# 设置 npm 全局安装路径
export PATH="$PATH:/usr/local/bin"

重新加载 ~/.zshrc 文件

保存对 ~/.zshrc 文件的更改并退出编辑器,然后在终端中运行以下命令以重新加载配置文件:

bash 复制代码
sh
复制代码
source ~/.zshrc

验证命令

通过以下命令检查和验证配置:

bash 复制代码
sh
复制代码
which flutter
flutter doctor

which yarn
yarn --version

示例 ~/.zshrc 文件

以下是一个示例 ~/.zshrc 文件,展示了如何配置 nvm、Flutter 和 yarn

bash 复制代码
sh
复制代码
# 设置 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

# 设置 Flutter
export PATH="$PATH:$HOME/flutter/bin"

# 设置 npm 全局安装路径
export PATH="$PATH:/usr/local/bin"

通过这些步骤,你可以确保全局安装的命令行工具在终端中可以正确使用。如果你有任何其他工具需要配置,只需确保将它们的路径添加到 PATH 环境变量中即可。

补充:mac 上安装命令

brew install yarn

相关推荐
蔓越莓几秒前
[Electron] win.setSize 在RTL布局下的表现,是否需要适配?
前端·electron
Json_5 分钟前
Vue 实例方法
前端·vue.js·深度学习
数据攻城小狮子5 分钟前
Java Spring Boot 与前端结合打造图书管理系统:技术剖析与实现
java·前端·spring boot·后端·maven·intellij-idea
阿鲁冶夫19 分钟前
最佳实践初始化项目公用cli
前端
Json_33 分钟前
实例入门 实例属性
前端·深度学习
Json_33 分钟前
JS中的apply和arguments小练习
前端·javascript·深度学习
云只上1 小时前
前端界面在线excel编辑器 。node编写post接口获取文件流,使用传参替换表格内容展示、前后端一把梭。
前端·javascript·node.js·excel
Json_1 小时前
Vue Methods Option 方法选项
前端·vue.js·深度学习
刘 怼怼1 小时前
使用 Vue 重构 RAGFlow 实现聊天功能
前端·vue.js·人工智能·重构
Json_1 小时前
Vue v-bind指令
前端·vue.js·深度学习