Flutter. 适用于 GetX 5 的 CLI (命令行接口/工具)

我希望在新项目中使用 GetX 5 。但问题是 get_cli 安装的是 GetX 4 ,并且为 Binding 类生成了一个过时的模板。

这不是一个大问题,可以手动修复,但我同时也有一些小的改进一直想实现,因此我决定派生(fork)get_cli 并创建一个新包。

隆重推出 get_cli5


变更

已进行以下更改:

  • get_cli5 现在安装 GetX 版本 5.0.0-release-candidate-9.3.2 (目前最新的候选发布版本),而不是最新的稳定版本(4.7.2)。由于尖角号(caret)语法不适用于 RC 版本,因此如果将来有新版本发布,则需要在 pubspec.yaml 中手动修复。

  • 移除了之前用于选择 GetXPattern (MVVM)Clean 架构的对话框。现在它始终是 GetXPattern

  • 为了更好地遵循 MVVM 的命名约定,文件夹 modules 已重命名为 presentation

原来是这样的:

kotlin 复制代码
lib\     
    app\        
        data\     
        modules\

现在是这样的:

kotlin 复制代码
lib\     
    app\        
        data\     
        presentation\
  1. 移除了 pubspec.yaml 中的 sub_folder: false 选项。现在,默认情况下采用扁平结构,如下所示:
arduino 复制代码
  home\
       home_binding.dart
       home_controller.dart
       home_view.dart

无需额外的文件夹选项。

  1. Binding 类的模板已更新,以适应 GetX5

现在,取代以下内容的是:

dart 复制代码
class HomeBinding extends Bindings {    
     @override   
     void dependencies() {      
         Get.lazyPut<HomeController>(        
            () => HomeController(),      
         );   
     } 
}

会生成如下的代码:

dart 复制代码
class HomeBinding extends Binding {     
  @override     
  List<Bind> dependencies() {       
     return [          
        Bind.put<HomeController>(           
            HomeController(),          
        )       
     ];     
   }    
}
  1. 新增了 create service 命令。 (请阅读下文了解详情。)

安装

首先,停用 get_cli (如果它已被激活):

bash 复制代码
dart pub global deactivate get_cli

然后,激活 get_cli5

bash 复制代码
dart pub global activate get_cli5

用法

初始化项目

  1. 使用 View -> Command Palette... 或在终端运行 flutter create 来创建一个 Flutter 项目。
  2. 在终端运行 get init 命令。它将生成以下文件夹和文件:
  1. 向项目中添加视图 (View)

命令 get create page:settings 将会在 presentation 文件夹内部生成一个名为 settings 的文件夹。

同时,routes 文件夹内的路由也会随之更新。

如果想要的名称是 "game settings",请使用:

Bash

sql 复制代码
get create page:game-settings

命令。


3. 向项目中添加服务 (Service)

要在 data 文件夹中创建 AuthService,请使用:

bash 复制代码
get create service:auth

命令。它将生成一个带有工厂单例(factory singleton)的 auth_service.dart 文件。

dart 复制代码
class AuthService {
  AuthService._();
  static final _instance = AuthService._();
  factory AuthService() {
    return _instance;
  }
}

要在 data/auth 文件夹中创建 AuthService,请使用:

bash 复制代码
get create service:auth on auth

命令。如果 auth 文件夹不存在,它将被创建。

有关 get_cli 其他命令的更多信息,请查阅官方 get_cli文档

这个包显然是为了解决我自己的需求而创建的,但如果它能帮助到其他人,我会很高兴。

相关推荐
顾安r1 小时前
11.8 脚本网页 星际逃生
c语言·前端·javascript·flask
Hello.Reader1 小时前
Data Sink定义、参数与可落地示例
java·前端·网络
im_AMBER1 小时前
React 17
前端·javascript·笔记·学习·react.js·前端框架
谷歌开发者2 小时前
Web 开发指向标 | Chrome 开发者工具学习资源 (六)
前端·chrome·学习
一晌小贪欢2 小时前
【Html模板】电商运营可视化大屏模板 Excel存储 + 一键导出(已上线-可预览)
前端·数据分析·html·excel·数据看板·电商大屏·大屏看板
发现你走远了2 小时前
连接模拟器网页进行h5的调试(使用Chrome远程调试(推荐)) 保姆级图文
前端·chrome
街尾杂货店&3 小时前
css - 实现三角形 div 容器,用css画一个三角形(提供示例源码)简单粗暴几行代码搞定!
前端·css
顺凡4 小时前
删一个却少俩:Antd Tag 多节点同时消失的原因
前端·javascript·面试
小白路过4 小时前
CSS transform矩阵变换全面解析
前端·css·矩阵
爬山算法4 小时前
Redis(110)Redis的发布订阅机制如何使用?
前端·redis·bootstrap