欢呼雀跃吧,因为 React Query 配备了专属开发者工具!🥳
当你开始 React Query 之旅时,这些开发者工具将成为得力助手。它们能可视化 React Query 的内部运作机制,在你遇到棘手问题时,很可能为你节省数小时的调试时间!
请注意:目前开发者工具 暂不支持 React Native。若您有意协助我们实现跨平台支持,请随时告知!
激动消息:我们现已推出独立的 React Native React Query DevTools 包!这一新增功能提供原生支持,让你可以直接在 React Native 项目中集成开发者工具。立即查看并参与贡献:react-native-react-query-devtools
另有一款外部工具可通过仪表盘使用 React Query 开发者工具。了解更多并参与贡献:react-query-external-sync
注意:自第 5 版起,开发者工具已支持观察变更 (mutations)。
开发者工具是独立包,需单独安装:
npm i @tanstack/react-query-devtools
npm i @tanstack/react-query-devtools
或
pnpm add @tanstack/react-query-devtools
pnpm add @tanstack/react-query-devtools
或
yarn add @tanstack/react-query-devtools
yarn add @tanstack/react-query-devtools
或
bun add @tanstack/react-query-devtools
bun add @tanstack/react-query-devtools
对于 Next 13+ App 目录,必须将其作为开发依赖安装才能正常工作。
导入方式如下:
import { ReactQueryDevtools } from '@tanstack/react-query-devtools'
import { ReactQueryDevtools } from '@tanstack/react-query-devtools'
默认情况下,React Query 开发者工具仅在 process.env.NODE_ENV === 'development' 时包含在构建包中,因此无需担心生产环境构建时的排除问题。
浮动模式会将开发者工具作为固定浮动元素挂载在应用中,并在屏幕角落提供显示/隐藏开关。该开关状态会通过 localStorage 保存,并在页面刷新后保持记忆。
请将以下代码尽可能放置在 React 应用的顶层。越接近页面根节点,效果越好!
import { ReactQueryDevtools } from '@tanstack/react-query-devtools'
function App() {
return (
<QueryClientProvider client={queryClient}>
{/* 应用其他内容 */}
<ReactQueryDevtools initialIsOpen={false} />
</QueryClientProvider>
)
}
import { ReactQueryDevtools } from '@tanstack/react-query-devtools'
function App() {
return (
<QueryClientProvider client={queryClient}>
{/* 应用其他内容 */}
<ReactQueryDevtools initialIsOpen={false} />
</QueryClientProvider>
)
}
嵌入式模式将开发者工具作为固定元素显示在应用中,便于你在自有开发工具中使用我们的面板。
请将以下代码尽可能放置在 React 应用的顶层:
import { ReactQueryDevtoolsPanel } from '@tanstack/react-query-devtools'
function App() {
const [isOpen, setIsOpen] = React.useState(false)
return (
<QueryClientProvider client={queryClient}>
{/* 应用其他内容 */}
<button
onClick={() => setIsOpen(!isOpen)}
>{`${isOpen ? '关闭' : '打开'}开发者工具面板`}</button>
{isOpen && <ReactQueryDevtoolsPanel onClose={() => setIsOpen(false)} />}
</QueryClientProvider>
)
}
import { ReactQueryDevtoolsPanel } from '@tanstack/react-query-devtools'
function App() {
const [isOpen, setIsOpen] = React.useState(false)
return (
<QueryClientProvider client={queryClient}>
{/* 应用其他内容 */}
<button
onClick={() => setIsOpen(!isOpen)}
>{`${isOpen ? '关闭' : '打开'}开发者工具面板`}</button>
{isOpen && <ReactQueryDevtoolsPanel onClose={() => setIsOpen(false)} />}
</QueryClientProvider>
)
}
开发者工具默认排除在生产构建外。但可通过懒加载方式在生产环境使用:
import * as React from 'react'
import { QueryClient, QueryClientProvider } from '@tanstack/react-query'
import { ReactQueryDevtools } from '@tanstack/react-query-devtools'
import { Example } from './Example'
const queryClient = new QueryClient()
const ReactQueryDevtoolsProduction = React.lazy(() =>
import('@tanstack/react-query-devtools/build/modern/production.js').then(
(d) => ({
default: d.ReactQueryDevtools,
}),
),
)
function App() {
const [showDevtools, setShowDevtools] = React.useState(false)
React.useEffect(() => {
// @ts-expect-error
window.toggleDevtools = () => setShowDevtools((old) => !old)
}, [])
return (
<QueryClientProvider client={queryClient}>
<Example />
<ReactQueryDevtools initialIsOpen />
{showDevtools && (
<React.Suspense fallback={null}>
<ReactQueryDevtoolsProduction />
</React.Suspense>
)}
</QueryClientProvider>
)
}
export default App
import * as React from 'react'
import { QueryClient, QueryClientProvider } from '@tanstack/react-query'
import { ReactQueryDevtools } from '@tanstack/react-query-devtools'
import { Example } from './Example'
const queryClient = new QueryClient()
const ReactQueryDevtoolsProduction = React.lazy(() =>
import('@tanstack/react-query-devtools/build/modern/production.js').then(
(d) => ({
default: d.ReactQueryDevtools,
}),
),
)
function App() {
const [showDevtools, setShowDevtools] = React.useState(false)
React.useEffect(() => {
// @ts-expect-error
window.toggleDevtools = () => setShowDevtools((old) => !old)
}, [])
return (
<QueryClientProvider client={queryClient}>
<Example />
<ReactQueryDevtools initialIsOpen />
{showDevtools && (
<React.Suspense fallback={null}>
<ReactQueryDevtoolsProduction />
</React.Suspense>
)}
</QueryClientProvider>
)
}
export default App
调用 window.toggleDevtools() 将下载开发者工具包并显示。
若打包工具支持包导出,可使用以下导入路径:
const ReactQueryDevtoolsProduction = React.lazy(() =>
import('@tanstack/react-query-devtools/production').then((d) => ({
default: d.ReactQueryDevtools,
})),
)
const ReactQueryDevtoolsProduction = React.lazy(() =>
import('@tanstack/react-query-devtools/production').then((d) => ({
default: d.ReactQueryDevtools,
})),
)
TypeScript 用户需在 tsconfig 中设置 moduleResolution: 'nodenext',这要求 TypeScript 版本至少为 v4.7。