Sobes.tech
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 в зависимости от результата асинхронной операции.