为了进行graphql的查询和变异,我已经成功地使用了fetch和svelte-apollo(请参见https://github.com/timhall/svelte-apollo)。
我喜欢fetch方法的简单性。
Svelte-apollo具备订阅功能,我会尝试使其工作。
但是还有其他选择吗?
如何使用svelte消费graphql的订阅?
为了进行graphql的查询和变异,我已经成功地使用了fetch和svelte-apollo(请参见https://github.com/timhall/svelte-apollo)。
我喜欢fetch方法的简单性。
Svelte-apollo具备订阅功能,我会尝试使其工作。
但是还有其他选择吗?
如何使用svelte消费graphql的订阅?
这是我的解决方案,使用了Apollo:
import { ApolloClient } from 'apollo-client';
import { InMemoryCache } from 'apollo-cache-inmemory';
import { HttpLink } from 'apollo-link-http';
import { WebSocketLink } from 'apollo-link-ws';
import { split } from 'apollo-link';
import { getMainDefinition } from 'apollo-utilities';
const httpLink = new HttpLink({
uri: 'http://localhost:3000/graphql'
});
const wsLink = new WebSocketLink({
uri: `ws://localhost:3000/subscriptions`,
options: {
reconnect: true
}
});
const link = split(
// split based on operation type
({ query }) => {
const definition = getMainDefinition(query);
return (
definition.kind === 'OperationDefinition' &&
definition.operation === 'subscription'
);
},
wsLink,
httpLink,
);
const client = new ApolloClient({
link,
cache: new InMemoryCache()
});
import gql from 'graphql-tag';
client.subscribe({
query: gql`subscription { whatever }`
}).subscribe(result => console.log(result.data);