Apollo Client本地状态 - 已登录查询
创始人
2024-09-09 01:30:36
0

在Apollo Client中,可以使用Apollo Link State库来管理本地状态。以下是一个示例解决方法,用于在已登录查询时管理本地状态:

  1. 首先,安装必要的依赖项:
npm install apollo-link apollo-link-state apollo-cache-inmemory graphql-tag
  1. 创建一个本地状态的GraphQL查询:
// localState.graphql
import gql from 'graphql-tag';

export const GET_LOGIN_STATUS = gql`
  query GetLoginStatus {
    isLoggedIn @client
  }
`;

export const SET_LOGIN_STATUS = gql`
  mutation SetLoginStatus($isLoggedIn: Boolean!) {
    setLoginStatus(isLoggedIn: $isLoggedIn) @client
  }
`;
  1. 创建一个本地状态的resolvers配置文件:
// resolvers.js
import { GET_LOGIN_STATUS, SET_LOGIN_STATUS } from './localState.graphql';

export const resolvers = {
  Query: {
    isLoggedIn: (_root, _args, { cache }) => {
      const { isLoggedIn } = cache.readQuery({ query: GET_LOGIN_STATUS });
      return isLoggedIn;
    },
  },
  Mutation: {
    setLoginStatus: (_root, { isLoggedIn }, { cache }) => {
      cache.writeQuery({
        query: GET_LOGIN_STATUS,
        data: { isLoggedIn },
      });
      return null;
    },
  },
};
  1. 创建一个Apollo Client实例并将本地状态resolvers配置添加到Apollo Link中:
import { ApolloClient } from 'apollo-client';
import { HttpLink } from 'apollo-link-http';
import { InMemoryCache } from 'apollo-cache-inmemory';
import { ApolloLink } from 'apollo-link';
import { withClientState } from 'apollo-link-state';
import { resolvers } from './resolvers';

const cache = new InMemoryCache();

const stateLink = withClientState({
  cache,
  resolvers,
});

const httpLink = new HttpLink({
  uri: 'http://your-graphql-endpoint',
});

const client = new ApolloClient({
  cache,
  link: ApolloLink.from([stateLink, httpLink]),
});
  1. 在组件中使用本地状态查询和突变:
import React from 'react';
import { useQuery, useMutation } from '@apollo/react-hooks';
import { GET_LOGIN_STATUS, SET_LOGIN_STATUS } from './localState.graphql';

const MyComponent = () => {
  const { data } = useQuery(GET_LOGIN_STATUS);
  const [setLoginStatus] = useMutation(SET_LOGIN_STATUS);

  const handleLogin = () => {
    setLoginStatus({ variables: { isLoggedIn: true } });
  };

  const handleLogout = () => {
    setLoginStatus({ variables: { isLoggedIn: false } });
  };

  return (
    
{data.isLoggedIn ? ( ) : ( )}
); }; export default MyComponent;

以上示例展示了如何使用Apollo Client的本地状态来管理已登录查询。通过使用Apollo Link State和本地状态查询和突变,可以轻松地管理和更新本地状态。

相关内容

热门资讯

4分钟开挂!海贝之城辅助器,w... 4分钟开挂!海贝之城辅助器,werplan免费挂下载(实测教程开挂辅助工具);无需打开直接搜索打开薇...
教会透视"WePok... 教会透视"WePoker脚本实战效果"开挂(透视)辅助平台(9分钟了解专业教程)教会透视"WePok...
第一分钟开挂!皮皮广东游戏辅助... 第一分钟开挂!皮皮广东游戏辅助软件,衢州都莱辅助软件(分享开挂内幕开挂辅助下载)皮皮广东游戏辅助软件...
科技透视"wepok... 科技透视"wepoker开挂透视"开挂(透视)辅助神器(推荐几款新版教你攻略)科技透视"wepoke...
8分钟透视!旗圣麻将辅助,邳州... 8分钟透视!旗圣麻将辅助,邳州友友有没有辅助软件(2024教程开挂辅助插件);无需打开直接搜索加薇1...
盘点透视"wepok... 盘点透视"wepoker有没有辅助挂"开挂(透视)辅助下载(一分钟揭秘透视教程)盘点透视"wepok...
第一分钟透视!打大a辅助器,微... 第一分钟透视!打大a辅助器,微信卡农辅助(透视游戏开挂辅助脚本)>>您好:软件加薇136704302...
了解透视"微扑克发牌... 了解透视"微扑克发牌机制"开挂(透视)辅助挂(玩家爆料力荐教程)了解透视"微扑克发牌机制"开挂(透视...
第8分钟透视!杭州都莱app有... 第8分钟透视!杭州都莱app有辅助吗,边锋辅助装备(总算了解开挂辅助下载) 了解更多开挂安装加(13...
推荐透视"wpk辅助... 推荐透视"wpk辅助会封号最简单三个办法"开挂(透视)辅助神器(玩家必备教程透明挂教程)推荐透视"w...