问题描述
我正在与家人一起使用 Riverpod 的 FutureProvider。 FutureProvider 一次又一次地继续运行。它仅显示加载对话框。热重载也停止工作。 FutureProvider 在没有家人的情况下工作正常。请帮助找出问题所在。
final ephemerisProvider =
Provider((ref) => ApiService("https://localhost"));
final ephemerisFutureProvider = FutureProvider.family
.autodispose<EpheModel,Map<String,dynamic>>((ref,data) async {
var response = await ref.read(ephemerisProvider).getData(data);
print(EpheModel.fromJSON(response));
return EpheModel.fromJSON(response);
});
class Kundlis extends ConsumerWidget {
static const routeName = "/kundlis";
@override
Widget build(BuildContext context,ScopedReader watch) {
final AsyncValue<EpheModel> kundlis = watch(ephemerisFutureProvider({}));
return Scaffold(
appBar: AppBar(
title: Text("Kundlis"),),drawer: AppDrawer(),body: kundlis.when(
data: (kundli) => Center(child: Text(kundli.toString())),loading: () => ProgressDialog(message: "Fetching Details..."),error: (message,st) =>
CustomSnackBar.buildErrorSnackbar(context,'$message')));
}
}
class ApiService {
final String url;
ApiService(this.url);
Future<Map<String,dynamic>> getData(Map<String,dynamic> data) async {
try {
http.Response response = await http.post(url + "/ephe",headers: <String,String>{'Content-Type': 'application/json'},body: jsonEncode(data));
if (response.statusCode == 200) {
return data;
} else {
throw Exception("Error Fetching Details");
}
} on SocketException {
throw Exception("No Internet Connection");
} on HttpException {
throw Exception("Error Fetching Details");
}
}
}
解决方法
{} != {}
。由于 .family
,您每次调用 watch(ephemerisFutureProvider({}))
时都会创建一个全新的提供程序。要通过系列选择先前构建的提供程序,您必须传递相同的值。并且 {} 永远不会与 {} 完全相同,这是有保证的。 :)