Flutter for OpenHarmony 万能游戏库App实战 - 收藏功能实现

收藏功能是一个重要的用户功能。这篇文章我们来实现一个完整的收藏系统,包括收藏管理、多类型支持、以及收藏列表展示。通过这个功能,我们能展示如何构建一个跨功能的数据管理系统

收藏数据模型

FavoriteItem类代表一个收藏项:

dart 复制代码
class FavoriteItem {
  final String id;
  final String type;
  final String name;
  final String? imageUrl;
  final Map<String, dynamic> data;

  FavoriteItem({
    required this.id,
    required this.type,
    required this.name,
    this.imageUrl,
    required this.data,
  });
}

id是收藏项的唯一标识。
type表示收藏项的类型(pokemon、free_game、rick_morty等)。
data存储完整的项目数据,用于导航到详情页面。

收藏提供者

FavoritesProvider使用Provider模式管理收藏:

dart 复制代码
class FavoritesProvider extends ChangeNotifier {
  List<FavoriteItem> _favorites = [];

  List<FavoriteItem> get favorites => _favorites;

  bool isFavorite(String id, String type) {
    return _favorites.any((item) => item.id == id && item.type == type);
  }

  void toggleFavorite(FavoriteItem item) {
    final index = _favorites.indexWhere((f) => f.id == item.id && f.type == item.type);
    if (index >= 0) {
      _favorites.removeAt(index);
    } else {
      _favorites.add(item);
    }
    notifyListeners();
  }

  List<FavoriteItem> getFavoritesByType(String type) {
    return _favorites.where((item) => item.type == type).toList();
  }
}

toggleFavorite用来切换收藏状态。
getFavoritesByType用来获取特定类型的收藏。

收藏列表页面

FavoritesScreen展示所有收藏:

dart 复制代码
class FavoritesScreen extends StatelessWidget {
  const FavoritesScreen({super.key});

  @override
  Widget build(BuildContext context) {
    final l10n = AppLocalizations.of(context);
    
    return DefaultTabController(
      length: 4,
      child: Scaffold(
        appBar: AppBar(
          title: Text(l10n.favorites),
          bottom: TabBar(
            isScrollable: true,
            tabs: [
              Tab(text: '全部'),
              Tab(text: l10n.pokemon),
              Tab(text: l10n.freeGames),
              Tab(text: l10n.rickMorty),
            ],
          ),
        ),
        body: Consumer<FavoritesProvider>(
          builder: (context, favorites, _) {
            return TabBarView(
              children: [
                _FavoritesList(items: favorites.favorites, l10n: l10n),
                _FavoritesList(items: favorites.getFavoritesByType('pokemon'), l10n: l10n),
                _FavoritesList(items: favorites.getFavoritesByType('free_game'), l10n: l10n),
                _FavoritesList(items: favorites.getFavoritesByType('rick_morty'), l10n: l10n),
              ],
            );
          },
        ),
      ),
    );
  }
}

使用TabBar展示不同类型的收藏。
使用Consumer监听FavoritesProvider的变化。

收藏列表项

_FavoritesList展示收藏列表:

dart 复制代码
class _FavoritesList extends StatelessWidget {
  final List<FavoriteItem> items;
  final AppLocalizations l10n;

  const _FavoritesList({required this.items, required this.l10n});

  void _navigateToDetail(BuildContext context, FavoriteItem item) {
    switch (item.type) {
      case 'pokemon':
        final id = item.data['id'];
        if (id != null) {
          Navigator.push(
            context,
            MaterialPageRoute(builder: (_) => PokemonDetailScreen(pokemonId: id is int ? id : int.tryParse(id.toString()) ?? 1)),
          );
        }
        break;
      case 'free_game':
        final id = item.data['id'];
        if (id != null) {
          Navigator.push(
            context,
            MaterialPageRoute(builder: (_) => GameDetailScreen(gameId: id is int ? id : int.tryParse(id.toString()) ?? 1)),
          );
        }
        break;
      case 'rick_morty':
        Navigator.push(
          context,
          MaterialPageRoute(builder: (_) => CharacterDetailScreen(character: item.data)),
        );
        break;
    }
  }

根据收藏项的类型导航到对应的详情页面。

总结

这篇文章我们实现了一个完整的收藏系统。涉及到的知识点包括:

  • 数据模型 - 设计通用的收藏数据模型
  • 状态管理 - 使用Provider管理收藏状态
  • 多类型支持 - 支持多种类型的收藏
  • Tab导航 - 使用TabBar展示不同类型的收藏
  • 导航集成 - 从收藏列表导航到详情页面
  • 国际化 - 支持多语言显示

收藏功能展示了如何构建一个跨功能的数据管理系统 。通过合理的数据模型和状态管理,我们能为用户提供一个完整的收藏体验


欢迎加入开源鸿蒙跨平台社区:https://openharmonycrossplatform.csdn.net

相关推荐
用户8356290780517 小时前
Python 操作 PowerPoint OLE 对象
后端·python
光泽雨7 小时前
c#中的Type类型
开发语言·前端
见叶之秋8 小时前
C++基础入门指南
开发语言·c++
小江的记录本8 小时前
【Java基础】Java 8-21新特性:JDK21 LTS:虚拟线程、模式匹配switch、结构化并发、序列集合(附《思维导图》+《面试高频考点清单》)
java·数据库·python·mysql·spring·面试·maven
计算机安禾8 小时前
【c++面向对象编程】第42篇:模板特化与偏特化:为特定类型定制实现
开发语言·c++·算法
qq_401700418 小时前
Qt 项目中使用 QSS 的全面总结
开发语言·qt
张登杰踩8 小时前
DINOv2 with Registers 系列模型详解:Giant 版本规格、Register Token 机制与使用指南
python·numpy
玖釉-8 小时前
C++ 中的循环语句详解:while、do...while、for、嵌套循环与循环控制
开发语言·c++·算法
XMYX-08 小时前
37 - Go env 环境变量:配置管理与运行时控制
开发语言·golang
隐于花海,等待花开8 小时前
9. Python 文件与输入输出 深度解析
python