gpt4 book ai didi

flutter - RiverPod - 如何在不在小部件中的 AsyncValue 上等待使用 FutureProvider

转载 作者:行者123 更新时间:2023-12-03 18:53:26 25 4
gpt4 key购买 nike

我需要从 Firebase Cloud Firestore 获取 1 个字段 1 次。我如何使用 Widget 构建之外的提供程序完成此操作?
以下是我的组合提供商。 appStartupProvider是 FutureProvider,我想获得 bool firestore 中此 1 字段的值。但是,等待 appStartupProvider声明“'await' 应用于'AsyncValue',这不是'Future'”。

final accountStreamProvider = StreamProvider<Account>((ref) {
final database = ref.watch(databaseProvider);
return database != null ? database.accountStream() : const Stream.empty();
});

final _accountSetupCompleteProvider = Provider<AsyncValue<bool>>((ref) {
return ref
.watch(accountStreamProvider)
.whenData((account) => account?.accountSetupComplete ?? false);
});

final appStartupProvider = FutureProvider<bool>((ref) async {
final accountSetupComplete = await ref.watch(_accountSetupCompleteProvider);

return accountSetupComplete;
});
显然这里缺少一些关于组合提供者和 AsyncValue 的关键知识,但我正在努力完成 RiverPod Combining Providers 上所述的情况。页面,我看到 await 正在使用。
enter image description here

最佳答案

在您发帖时,文档中的示例不正确。它已经更新,现在是正确的。
你可以这样写:

final accountStreamProvider = StreamProvider<Account?>((ref) {
final database = ref.watch(databaseProvider);
return database != null ? database.accountStream() : const Stream.empty();
});

final _accountSetupCompleteProvider = FutureProvider<bool>((ref) async {
final account = await ref.watch(accountStreamProvider.last);
return account?.accountSetupComplete ?? false;
});

final appStartupProvider = FutureProvider<bool>((ref) async {
final accountSetupComplete = await ref.watch(_accountSetupCompleteProvider.future);
return accountSetupComplete;
});
或者:
final accountStreamProvider = StreamProvider<Account?>((ref) {
final database = ref.watch(databaseProvider);
return database != null ? database.accountStream() : const Stream.empty();
});

final _accountSetupCompleteProvider = Provider<AsyncValue<bool>>((ref) {
return ref
.watch(accountStreamProvider)
.whenData((account) => account?.accountSetupComplete ?? false);
});

final appStartupProvider = Provider<bool>((ref) {
final accountSetupComplete = ref.watch(_accountSetupCompleteProvider).maybeWhen(
data: (data) => data,
orElse: () => false,
);

return accountSetupComplete;
});

关于flutter - RiverPod - 如何在不在小部件中的 AsyncValue 上等待使用 FutureProvider,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/66411312/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com