Skip to content
Документация
Условная выборка данных

Условная выборка

Условная

Используйте null или передайте функцию в качестве key для условной выборки данных. Если функция выводит ошибку или возвращает ложное значение, SWR не отправляет запрос.

// условная выборка
const { data } = useSWR(shouldFetch ? '/api/data' : null, fetcher)
 
// ...или вернуть ложное значение
const { data } = useSWR(() => shouldFetch ? '/api/data' : null, fetcher)
 
// ...или вывести ошибку, если user.id не определен
const { data } = useSWR(() => '/api/data?uid=' + user.id, fetcher)

Зависимая

SWR также позволяет получать данные, которые зависят от других данных. Это обеспечивает максимально возможный параллелизм (избегая водопадов), а также последовательную выборку, когда для следующей выборки данных требуется фрагмент динамических данных.

function MyProjects () {
  const { data: user } = useSWR('/api/user')
  const { data: projects } = useSWR(() => '/api/projects?uid=' + user.id)
  // При передаче функции SWR будет использовать возвращаемое значение
  // как `key`. Если функция выдает ошибку или возвращает ложь,
  // SWR будет знать, что некоторые зависимости не готовы.
  // В этом случае `user.id` выдает ошибку, когда `user` не загружен.
 
  if (!projects) return 'загрузка...'
  return 'У вас ' + projects.length + ' проектов'
}