窗口聚焦重新获取数据

窗口焦点重新获取

如果用户离开你的应用后又返回,并且查询数据已过期(stale),TanStack Query 会自动在后台为你请求最新的数据。你可以通过 refetchOnWindowFocus 选项来全局或针对单个查询禁用此功能:

全局禁用

//
const queryClient = new QueryClient({
  defaultOptions: {
    queries: {
      refetchOnWindowFocus: false, // 默认值: true
    },
  },
})

function App() {
  return <QueryClientProvider client={queryClient}>...</QueryClientProvider>
}

单个查询禁用

useQuery({
  queryKey: ['todos'],
  queryFn: fetchTodos,
  refetchOnWindowFocus: false,
})

自定义窗口焦点事件

在极少数情况下,你可能希望自行管理触发 TanStack Query 重新验证的窗口焦点事件。为此,TanStack Query 提供了 focusManager.setEventListener 函数。该函数会提供一个回调函数,当窗口获得焦点时应调用此回调,并允许你设置自己的事件监听器。调用 focusManager.setEventListener 时,之前设置的处理器(大多数情况下是默认处理器)会被移除,转而使用你的新处理器。例如,以下是默认的处理器:

在 React Native 中管理焦点

React Native 不使用 window 上的事件监听器,而是通过 AppState 模块arrow-up-right 提供焦点信息。你可以使用 AppState 的 "change" 事件,在应用状态变为 "active" 时触发更新:

管理焦点状态

最后更新于