flutter 自动生成静态资源的引用

flutter_gen库的使用

第一步、项目yarml中dev_dependencies 新增一下flutter_gen_runner 和build_runner

dev_dependencies:
  build_runner: null
  flutter_gen_runner: null # flutter packages pub run build_runner build

第二步、新增配置信息 和(dev_dependencies 同级的)

# 图片资源本地化命令行 flutter packages pub run build_runner build
flutter_gen:
  output: lib/gen/ # Optional (default: lib/gen/)
  lineLength: 80 # Optional (default: 80)

  # Optional
  integrations:
    flutter_svg: true
    flare_flutter: true
    rive: true
    lottie: true

  assets:
    enabled: true

第三步下载安装 flutter_gen

dart pub global activate flutter_gen

第四步、直接使用命令生成

flutter packages pub run build_runner build

Flutter框架中,为了方便开发者处理数据模型,官方提供了一个名为`flutter_gen`的插件。这个插件能够自动生成类中的getter 和setter 方法,并帮助处理一些常见的编码工作,如生成JSON序列化和反序列化的代码。 ### `flutter_gen` 的基本用法 #### 安装步骤: 首先,在你的 Flutter 项目中运行以下命令安装`flutter_gen`插件: ```bash flutter pub add flutter_gen ``` 接着,在你的项目中添加相应的依赖项到 `pubspec.yaml` 文件中: ```yaml dependencies: flutter_gen: ^1.5.0 ``` #### 使用方法: 创建一个需要生成 getter 和 setter 的数据类,比如我们有一个简单的 User 类: ```dart class _UserState extends State<User> { @override Widget build(BuildContext context) { return Scaffold( appBar: AppBar( title: Text('User Details'), ), body: Column( children: [ ... // 其他 UI 控制部分 Expanded(child: Container(child: _buildDetails(_user))), ], ), ); } Widget _buildDetails(User user) { return Text("Name: ${user.name}"); } } class User { String name; factory User.fromMap(Map<String, dynamic> map) => User() ..name = map['name']; } ``` 在这段代码中,`User` 类有 `name` 属性,但并未显式定义获取 (`get`) 或设置 (`set`) 这个属性的函数。 #### 配置 `flutter_gen` 插件: 接下来,在项目的根目录下创建一个 `gen` 目录,然后将一个 `.json` 文件放进去,用于配置 `flutter_gen` 插件如何生成代码。假设文件名为 `config.json`,内容可以像下面这样: ```json { "name": "User", "fields": ["name"] } ``` 在这个 `.json` 文件中,`name` 关键字指定要生成代码的数据类名称,`fields` 数组包含了该类的字段列表。 最后,在你的 `main.dart` 或者其他启动文件中导入并使用 `flutter_gen` 插件: ```dart import 'package:flutter_gen/flutter_gen.dart'; void main() => runApp(MyApp()); class MyApp extends StatelessWidget { @override Widget build(BuildContext context) { return MaterialApp( title: 'Flutter Gen Example', home: MyHomePage(), ); } } class MyHomePage extends StatefulWidget { @override _MyHomePageState createState() => _MyHomePageState(); } class _MyHomePageState extends State<MyHomePage> { User user; void initState() { super.initState(); // 初始化用户数据 user = User(); } Widget _buildDetails() { return Text("Name: ${user.name}"); // 此处会自动转换成正确的 getter 调用 } @override Widget build(BuildContext context) { return Scaffold( appBar: AppBar(title: Text('User Details')), body: Center( child: _buildDetails(), // 这里无需手动添加 getter 调用了 ), ); } } ``` 通过以上步骤,`flutter_gen` 插件将会根据配置文件自动生成对应的 getter 和 setter 函数,并应用于整个应用中。这使得数据处理变得更加简洁和高效。 --- ###
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

肥肥呀呀呀

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值