flutter - Flutter StreamProvider '列表' 不是类型转换中类型 'List '的子类型
问题描述
我正在尝试使用 StreamProvider 使来自 Firestore 文档流的数据在我的整个应用程序中可用。它是一个食谱应用程序,这是购物清单。
我有一个模型 RecipeItem ,其中包含有关配方中项目的详细信息。firestore 文档保存一个值,它是一个数组,称为“列表”,其中包含列表中每个项目的映射。
以下是我与 Firestore 的连接和设置流。我尝试获取文档,然后用户映射为列表中的每个项目创建一个 RecipeItem 实例。这是方法:
Stream<List<RecipeItem>> getPersonalList() {
print('Fetching personal list');
return _db.collection('shopping_lists').document(userId).snapshots().map(
(DocumentSnapshot documentSnapshot) => documentSnapshot.data['list']
.map(
(item) =>
// print(item);
RecipeItem(
category: item['category'],
wholeLine: item['wholeLine'],
recipeTitle: item['recipeTitle'],
recipeId: item['recipeId'],
purchased: item['purchased'],
),
)
.toList(),
);
}
现在在 main.dart 我有一个寻找类型的 StreamProvider<List<RecipeItem>>
class MyApp extends StatelessWidget {
// This widget is the root of your application.
@override
Widget build(BuildContext context) {
return MultiProvider(
providers: [
StreamProvider<FirebaseUser>(
//Access withing the app -> var user = Provider.of<FirebaseUser>(context);
create: (_) => AuthService().user),
StreamProvider<List<RecipeItem>>(
create: (_) => PersonalListDB().getPersonalList(),
catchError: (context, error) {
print('This is the error from stream provider *** $error');
},
),
ChangeNotifierProvider(
create: (_) => RecipesDB(),
)
],
child: MaterialApp(
etc etc...
当我运行这个我得到这个错误:
类型“列表”不是类型转换中“列表”类型的子类型
我可以解决这个问题的唯一方法是,如果我必须在任何地方进行List<RecipeItem>
更改List<dynamic>
。这可行,但似乎不是正确的解决方案。
我已经尝试了几(一百万)件事。
我在这里找到了这篇文章:Getting type 'List<dynamic>' is not a subtype of type 'List<...>' error in JSON
这告诉我 .toList() 可能是问题,因为它创建了 List。所以我尝试使用 List.from 和使用 .cast<List> 但没有运气。更让我困惑的是,我非常密切地关注其他教程做类似的事情。
非常感谢任何解决此问题并帮助我理解问题的帮助。
解决方案
Firestore 列表(db、httpRequest 等)的类型是动态的,以避免在调用它们时出现问题,您可以尝试告诉地图您尝试投射什么类型的对象
return _db.collection('shopping_lists').document(userId).snapshots().map<List<RecipeItem>>( //I'm not sure what kind of object this map should return, is this the method map part of the stream? if it is then it should be of type List<RecipeItem>
(DocumentSnapshot documentSnapshot) => documentSnapshot.data['list']
.map<RecipeItem>( //now it will know it's not a dynamic value but of type RecipeItem
(item) =>
// print(item);
RecipeItem(
category: item['category'],
wholeLine: item['wholeLine'],
recipeTitle: item['recipeTitle'],
recipeId: item['recipeId'],
purchased: item['purchased'],
),
)
.toList(),
);
推荐阅读
- reactjs - SyntaxError:无法在模块外部使用导入语句 - 核心 UI - React JS
- r - 对发现的每一年进行数据处理
- mongodb - MongoDb 聚合格式输出
- ruby - Ruby 将 csv 日期格式化为无效日期(argumentError)
- vba - Microsoft Visio VBA CustomUI 功能区帮助 - 更改 EditBox 的默认值
- sql - 如何在 Laravel Eloquent 中使用 DISTINCT ON
- node.js - 如何删除 MongoDB 中的 ObjectID 数组?
- ios - 单击按钮后如何从tabview中隐藏/删除视图
- charts - 如何使用 billboard.js 制作每日时间表?
- reactjs - 在 store 初始化后立即调度 Redux Saga Actions 而不是 useEffect