Back to questions
Junior — Middle
83
Мог бы ты привести пример применения виджета FutureBuilder в своем проекте?
Answer from AI
sobes.tech AI
В одном из проектов я использовал FutureBuilder для асинхронной загрузки данных с сервера и отображения их в интерфейсе. Например, при загрузке списка пользователей из API:
Future<List<User>> fetchUsers() async {
final response = await http.get(Uri.parse('https://api.example.com/users'));
if (response.statusCode == 200) {
return parseUsers(response.body);
} else {
throw Exception('Failed to load users');
}
}
Widget build(BuildContext context) {
return FutureBuilder<List<User>>(
future: fetchUsers(),
builder: (context, snapshot) {
if (snapshot.connectionState == ConnectionState.waiting) {
return CircularProgressIndicator();
} else if (snapshot.hasError) {
return Text('Ошибка: \\${snapshot.error}');
} else if (snapshot.hasData) {
return ListView(
children: snapshot.data!.map((user) => ListTile(title: Text(user.name))).toList(),
);
} else {
return Text('Нет данных');
}
},
);
}
Такой подход позволяет удобно управлять состояниями загрузки и отображать UI в зависимости от результата асинхронной операции.