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),
      ),
    );
  }
}

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

相关推荐
王码码20351 小时前
Flutter 组件 inappwebview_cookie_manager 适配 鸿蒙Harmony 实战 - 驾驭核心大 Web 容器缓存隧道、构建金融级政企应用绝对防串号跨域大隔离基座
flutter·harmonyos·鸿蒙·openharmony·inappwebview_cookie_manager
左手厨刀右手茼蒿1 小时前
Flutter 组件 ews 的适配 鸿蒙Harmony 实战 - 驾驭企业级 Exchange Web Services 协议、实现鸿蒙端政企办公同步与高安通讯隔离方案
flutter·harmonyos·鸿蒙·openharmony
钛态1 小时前
Flutter 三方库 react 泛前端核心范式框架鸿蒙原生层生态级双向超能适配:跨时空重塑响应式单向数据流拓扑与高度精密生命周期树引擎解耦视图渲染控制中枢(适配鸿蒙 HarmonyOS ohos)
前端·flutter·react.js
键盘鼓手苏苏1 小时前
Flutter 组件 spry 适配鸿蒙 HarmonyOS 实战:轻量化 Web 框架,构建高性能端侧微服务与 Middleware 治理架构
flutter·harmonyos·鸿蒙·openharmony
wey6082 小时前
使用taro 开发 flutter应用
flutter
装不满的克莱因瓶3 小时前
【2026 持续更新】Flutter 零基础到精通全攻略(一)
flutter·app·dart·移动端
装不满的克莱因瓶4 小时前
React Native vs Flutter:一次深入到底的性能对比分析(含原理 + 实战)
javascript·flutter·react native·react.js·app·移动端
亚历克斯神5 小时前
Flutter 组件 t_stats 的适配 鸿蒙Harmony 实战 - 驾驭高性能统计学运算、实现鸿蒙端海量数据实时态势感知与工业级描述性统计方案
flutter·harmonyos·鸿蒙·openharmony·t_stats
键盘鼓手苏苏5 小时前
Flutter 组件 angel3_orm_mysql 的适配 鸿蒙Harmony 实战 - 驾驭专业 ORM 映射引擎、实现鸿蒙端与 MySQL 数据库的透明映射与高性能 SQL 审计方案
flutter·harmonyos·鸿蒙·openharmony·angel3_orm_mysql
左手厨刀右手茼蒿5 小时前
Flutter 组件 serverpod_swagger 的适配 鸿蒙Harmony 实战 - 驾驭 API 文档自动化、实现鸿蒙端全栈联调与 Swagger UI 动态审计方案
flutter·harmonyos·鸿蒙·openharmony·serverpod_swagger