查看源代码,没有可以为ApolloClient设置的方法或cachePolicy变量。
您可以创建一个单例 Apollo 客户端类,并添加您自己的带有所需缓存策略的 fetch 方法,就像这样
class ApolloManager {
static let shared = Apollo()
private var client: ApolloClient!
var store: ApolloStore { return self.client.store }
static func configure(url: URL, configuration: URLSessionConfiguration? = nil) {
let store = ApolloStore(cache: InMemoryNormalizedCache())
Apollo.shared.client = ApolloClient(networkTransport: HTTPNetworkTransport(url: url, configuration: configuration ?? .default), store: store)
}
@discardableResult
func fetch<Query: GraphQLQuery>(query: Query, cachePolicy: CachePolicy = .fetchIgnoringCacheData, queue: DispatchQueue = .main, resultHandler: OperationResultHandler<Query>? = nil) -> Cancellable? {
return self.client.fetch(query: query, cachePolicy: cachePolicy, queue: queue, resultHandler: resultHandler)
}
}
Initializer可以添加到AppDelegate.swift的didFinishLaunchingWithOptions方法中
let url = URL(string: "http://192.168.1.4:2223")!
ApolloManager.configure(url: url)
你也可以用configuration初始化你的客户端
let configuration = URLSessionConfiguration.default
configuration.httpAdditionalHeaders = ["Authorization": "token"]
ApolloManager.configure(url: url, configuration: configuration)
用法
ApolloManager.shared.fetch(query: getUser)