Flutter依赖注入使用指南

1. 手动依赖注入

最简单的方式,通过构造函数传递依赖:

Dart 复制代码
class ApiService {
  Future<String> fetchData() async {
    // API 调用
    return 'Data';
  }
}

class UserRepository {
  final ApiService apiService;
  
  UserRepository(this.apiService);
  
  Future<String> getUserData() {
    return apiService.fetchData();
  }
}

class MyWidget extends StatelessWidget {
  final UserRepository userRepository;
  
  MyWidget({required this.userRepository});
  
  @override
  Widget build(BuildContext context) {
    return Text('User: ${userRepository.getUserData()}');
  }
}

// 使用
void main() {
  final apiService = ApiService();
  final userRepository = UserRepository(apiService);
  runApp(MyApp(userRepository: userRepository));
}

2. 使用 Provider 包

最流行的 Flutter 状态管理和依赖注入方案:

Dart 复制代码
dependencies:
  provider: ^6.0.5
Dart 复制代码
import 'package:provider/provider.dart';

// 定义服务类
class CounterService {
  int _count = 0;
  int get count => _count;
  
  void increment() {
    _count++;
  }
}

void main() {
  runApp(
    MultiProvider(
      providers: [
        Provider<CounterService>(create: (_) => CounterService()),
        // 可以添加更多 provider
      ],
      child: MyApp(),
    ),
  );
}

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      home: MyHomePage(),
    );
  }
}

class MyHomePage extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    final counterService = Provider.of<CounterService>(context);
    
    return Scaffold(
      body: Center(
        child: Text('Count: ${counterService.count}'),
      ),
      floatingActionButton: FloatingActionButton(
        onPressed: () {
          counterService.increment();
        },
        child: Icon(Icons.add),
      ),
    );
  }
}

依赖注入是将对象的创建和使用分离,使代码更加灵活、可测试和可维护

相关推荐
liulian09161 小时前
Flutter for OpenHarmony 跨平台技术实战:flutter_animate 与 pull_to_refresh 库的鸿蒙化适配总结
flutter·华为·学习方法·harmonyos
IntMainJhy2 小时前
【flutter for open harmony】第三方库 Flutter 二维码生成的鸿蒙化适配与实战指南
数据库·flutter·华为·sqlite·harmonyos
jiejiejiejie_3 小时前
Flutter for OpenHarmony 底部选项卡与多语言适配小记:让 App 更贴心的两次小升级✨
flutter·华为·harmonyos
jiejiejiejie_3 小时前
Flutter for OpenHarmony 应用更新检测与萌系搜索功能实战小记✨
flutter·华为·harmonyos
IntMainJhy4 小时前
Flutter 三方库 Firebase Messaging 鸿蒙化适配与实战指南(权限检查+设备Token获取全覆盖)
flutter·华为·harmonyos
liulian09165 小时前
Flutter 依赖注入与设备信息库:get_it 与 device_info_plus 的 OpenHarmony 适配指南总结
flutter·华为·学习方法·harmonyos
里欧跑得慢5 小时前
微交互设计模式:提升用户体验的细节之美
前端·css·flutter·web
stringwu6 小时前
Flutter GetX 核心坑及架构选型与可替换性方案
前端·flutter
IntMainJhy6 小时前
【flutter for open harmony】第三方库Flutter 国际化多语言的鸿蒙化适配与实战指南
数据库·flutter·华为·sqlite·harmonyos
liulian09166 小时前
【Flutter for OpenHarmony 】地图功能适配与位置显示实现指南
flutter·华为·学习方法·harmonyos