在Apollo Client 3中,returnPartialData选项可以用来在未完成查询时返回缓存数据。这意味着即使GraphQL查询未能成功,Apollo仍然可以从缓存中返回部分数据。例如:
const { data, loading, error } = useQuery(GET_DATA, {
variables: { id },
returnPartialData: true
});
但是,即使没有明确定义的字段策略,Apollo Client仍然会使用它的默认策略。默认策略是在查询之前将所有未缓存的字段标记为NetworkOnly,而不是仅返回已缓存的字段。因此,即使没有指定字段策略,returnPartialData仍可以缓存将要被查询的字段。这就是为什么returnPartialData可以在没有字段策略的情况下工作的原因。
如果您需要自定义默认字段策略,可以在Apollo Client实例化时为其提供缺省选项。例如:
const client = new ApolloClient({
cache: new InMemoryCache(),
link: new HttpLink(),
defaultOptions: {
watchQuery: {
fetchPolicy: 'cache-and-network',
errorPolicy: 'ignore',
},
query: {
fetchPolicy: 'cache-and-network',
errorPolicy: 'all',
},
},
});
在这个示例中,我们将fetchPolicy设置为'cache-and-network',这意味着Apollo将始终首先检查缓存。如果缓存中没有数据可用,Apollo会使用网络请求获取数据。