Flutter 版的 NVM——FVM 使用指南

what is FVM?

FVM(Flutter Version Management) 是一个用于管理多个 Flutter SDK 版本的工具,类似于 Node.js 开发者常用的 NVM。

解决了什么问题?

  • 不同项目需要不同 Flutter 版本
  • 全局只有一个版本,切换麻烦
  • 团队成员版本不一致导致构建失败

安装 FVM

macOS / Linux

bash 复制代码
brew install fvm

Windows(需要先安装 Dart)

bash 复制代码
dart pub global activate fvm

安装完成后,确保将 Dart 全局 bin 目录加入 PATH。

快速上手

1. 安装指定版本

bash 复制代码
fvm install 3.24.0
fvm install 3.19.0
fvm install xxxx

2. 在项目中使用和全局使用

bash 复制代码
## 项目切换
cd /项目目录
fvm use 3.24.0

执行后会自动生成 .fvm 配置文件和 fvm_config.json

bash 复制代码
## 全局切换
fvm use 3.24.0 --global
对比项 fvm use X --global fvm use X
作用范围 整台机器 当前项目
生成文件 ~/.fvm/ ./.fvm/
Git 管理 ❌ 不提交 ✅ 可以提交
优先级 低(被项目配置覆盖)

最佳实践 :个人开发用 --global不用管的那么严格不会污染项目代码,团队项目不带 --global 并提交配置,还是严格一些好。

3. 运行 Flutter 命令

bash 复制代码
# 通过 fvm 调用(推荐)
fvm flutter run
fvm flutter build apk

# 或激活全局版本
fvm use 3.24.0 --global

4. 查看已安装版本

bash 复制代码
fvm list

输出示例:

复制代码
Cached versions:
  3.24.0
  3.19.0

团队协作最佳实践

1. 提交 FVM 配置到 Git

在项目根目录执行:

bash 复制代码
fvm use 3.24.0
git add .fvm fvm_config.json
git commit -m "Add FVM configuration"

2. 配置 .gitignore

bash 复制代码
# FVM
.fvm/flutter_sdk/

3. 新成员入职

bash 复制代码
git clone <your-repo>
fvm install
fvm use

一行命令搞定环境同步!

工作原理

FVM 将各版本 SDK 安装在统一目录(和nvm大差不差):

复制代码
~/.fvm/versions/
├── 3.24.0/
└── 3.19.0/

通过软链接和 PATH 优先级,实现不同项目使用不同版本。

常用命令速查

命令 说明
fvm install <version> 安装 Flutter 版本
fvm use <version> 切换项目版本
fvm use <version> --global 设置全局默认版本
fvm list 查看已安装版本
fvm remove <version> 删除指定版本
fvm flutter <args> 运行 Flutter 命令
fvm doctor 检查 FVM 状态

更新 FVM 自身

方式一:Homebrew(macOS/Linux)

bash

复制

复制代码
brew upgrade fvm

方式二:Dart pub global(Windows)

bash

复制

复制代码
dart pub global activate fvm

activate 会自动更新到最新版本

方式三:手动下载

GitHub Releases 下载新版,覆盖旧文件即可。


验证当前版本

bash

复制

复制代码
fvm --version

注意 :FVM 更新的是工具本身 ,Flutter SDK 版本是独立的------更新 FVM 不会影响你已经通过它安装的 3.24.03.19.0 等 SDK 版本。

总结

FVM 是 Flutter 开发者必备的多版本管理工具,和mvm一样(虽然nvm问题也很多)。

推荐团队统一使用 FVM 管理 Flutter 版本,配合 Git 配置实现环境一致性。

如果fvm自己要更新


💡 如果你还有其他 Flutter 开发工具推荐,欢迎补一下!

相关链接:

相关推荐
Justin在掘金4 小时前
Riverpod 实战指南
flutter
MonkeyKing71559 小时前
Flutter Riverpod 2.x 设计思想与最佳实践
前端·flutter
梦想不只是梦与想10 小时前
Flutter中 yield*关键字
flutter·生成器函数
用户游民12 小时前
Flutter GetX实现原理
前端·flutter
MonkeyKing715512 小时前
Flutter列表性能极致优化:从卡顿到丝滑
flutter
恋猫de小郭13 小时前
实用性 Max ,新 Flutter & Dart Agent Skills 深度解读
android·前端·flutter
Jolyne_1 天前
flutter学习(一)环境搭建及基础速通
flutter
MonkeyKing71551 天前
Flutter状态管理实战:全局、局部、页面状态拆分指南
前端·flutter
MonkeyKing71551 天前
Flutter异步状态统一处理实战:告别混乱,优雅管理请求与加载
flutter
MonkeyKing71551 天前
Flutter项目结构与模块化、组件化、插件化
flutter