重要提示:该工具目前处于实验阶段。这意味着在次要版本和补丁版本中都可能出现破坏性变更。使用时需自行承担风险。如果您选择在生产环境中依赖此实验阶段的功能,请将版本锁定到具体的补丁版本以避免意外中断。
broadcastQueryClient 是一个用于在同源浏览器标签页/窗口之间广播和同步 queryClient 状态的工具。
该工具作为独立包提供,可通过 '@tanstack/query-broadcast-client-experimental' 导入。
导入 broadcastQueryClient 函数,传入您的 QueryClient 实例,并可选地设置 broadcastChannel。
import { broadcastQueryClient } from '@tanstack/query-broadcast-client-experimental'
const queryClient = new QueryClient()
broadcastQueryClient({
queryClient,
broadcastChannel: 'my-app',
})
import { broadcastQueryClient } from '@tanstack/query-broadcast-client-experimental'
const queryClient = new QueryClient()
broadcastQueryClient({
queryClient,
broadcastChannel: 'my-app',
})
向该函数传入一个 QueryClient 实例,并可选择性地传入 broadcastChannel。
broadcastQueryClient({ queryClient, broadcastChannel })
broadcastQueryClient({ queryClient, broadcastChannel })
选项对象:
interface BroadcastQueryClientOptions {
/** 需要同步的 QueryClient */
queryClient: QueryClient
/** 用于在标签页和窗口之间通信的唯一频道名称 */
broadcastChannel?: string
/** BroadcastChannel API 的选项 */
options?: BroadcastChannelOptions
}
interface BroadcastQueryClientOptions {
/** 需要同步的 QueryClient */
queryClient: QueryClient
/** 用于在标签页和窗口之间通信的唯一频道名称 */
broadcastChannel?: string
/** BroadcastChannel API 的选项 */
options?: BroadcastChannelOptions
}
默认选项为:
{
broadcastChannel = 'tanstack-query',
}
{
broadcastChannel = 'tanstack-query',
}