>웹 프론트엔드 >JS 튜토리얼 >React와 GraphQL을 사용하여 유연한 프런트엔드 및 백엔드 데이터 상호 작용을 구축하는 방법

React와 GraphQL을 사용하여 유연한 프런트엔드 및 백엔드 데이터 상호 작용을 구축하는 방법

王林
王林원래의
2023-09-28 20:30:111693검색

React와 GraphQL을 사용하여 유연한 프런트엔드 및 백엔드 데이터 상호 작용을 구축하는 방법

React 및 GraphQL을 사용하여 유연한 프런트엔드 및 백엔드 데이터 상호작용을 구축하는 방법

현대 웹 애플리케이션 개발에서는 프런트엔드 및 백엔드 데이터 상호작용이 필수적입니다. 효율적이고 유연하며 확장 가능한 데이터 상호 작용을 달성하려면 React와 GraphQL을 조합하여 사용하는 것이 좋습니다. 이 기사에서는 React와 GraphQL을 사용하여 유연한 프런트엔드 및 백엔드 데이터 상호 작용을 구축하는 방법을 소개하고 구체적인 코드 예제를 제공합니다.

1. GraphQL이란 무엇인가요?

GraphQL은 API용 쿼리 언어 및 런타임에 대한 사양 집합입니다. 이는 프런트 엔드 애플리케이션에 필요한 데이터를 설명하는 유연한 방법을 제공하고 네트워크 요청 수를 줄이고 데이터 수집 효율성을 크게 향상시킬 수 있습니다. 기존 RESTful API와 비교하여 GraphQL을 사용하면 프런트엔드 애플리케이션이 여러 엔드포인트에서 불필요한 데이터를 가져올 필요 없이 가져와야 하는 데이터를 정확하게 지정할 수 있습니다.

2. React와 GraphQL을 어떻게 사용하나요?

  1. 관련 종속성 설치

먼저 몇 가지 필수 종속성을 설치해야 합니다. 명령줄 도구를 열고 프로젝트 디렉터리를 입력한 후 다음 명령을 실행합니다.

npm install react react-dom react-apollo graphql apollo-boost
  1. Create Apollo Client

React 애플리케이션에서는 Apollo Client를 사용하여 GraphQL 서버와의 통신을 관리할 수 있습니다. 먼저 프로젝트의 엔트리 파일(보통 index.js)을 열고 다음과 같이 Apollo 클라이언트를 생성합니다.

import React from 'react';
import { ApolloProvider } from 'react-apollo';
import ApolloClient from 'apollo-boost';

const client = new ApolloClient({
  uri: 'http://localhost:4000/graphql' // GraphQL服务器的URL
});

ReactDOM.render(
  <ApolloProvider client={client}>
    <App />
  </ApolloProvider>,
  document.getElementById('root')
);
  1. Send GraphQL query

React 컴포넌트에서는 에서 제공하는 Query를 사용할 수 있습니다. GraphQL 쿼리를 보내고 데이터를 가져오는 Apollo 클라이언트 구성 요소입니다. 예는 다음과 같습니다. Query组件来发送GraphQL查询并获取数据。以下是一个示例:

import React from 'react';
import { Query } from 'react-apollo';
import gql from 'graphql-tag';

const GET_USER = gql`
  query GetUser($id: ID!) {
    user(id: $id) {
      id
      name
      email
    }
  }
`;

const User = ({ id }) => (
  <Query query={GET_USER} variables={{ id }}>
    {({ loading, error, data }) => {
      if (loading) return <p>Loading...</p>;
      if (error) return <p>Error :(</p>;

      const { user } = data;

      return (
        <div>
          <p>Name: {user.name}</p>
          <p>Email: {user.email}</p>
        </div>
      );
    }}
  </Query>
);

在上面的代码中,我们定义了一个GET_USER的GraphQL查询,并将其作为query属性传递给Query组件。我们还通过variables属性传递了查询所需的变量。在组件的回调函数中,我们可以访问loadingerrordata等信息。根据这些信息,我们可以在页面上显示相应的内容。

  1. 发送GraphQL变更

除了发送查询,我们还可以使用Apollo Client提供的Mutation组件来发送GraphQL变更。以下是一个示例:

import React from 'react';
import { Mutation } from 'react-apollo';
import gql from 'graphql-tag';

const CREATE_USER = gql`
  mutation CreateUser($input: CreateUserInput!) {
    createUser(input: $input) {
      id
      name
      email
    }
  }
`;

const CreateUser = () => (
  <Mutation mutation={CREATE_USER}>
    {(createUser, { data }) => (
      <div>
        <button onClick={() => {
          createUser({ variables: { input: { name: 'John', email: 'john@example.com' } } })
        }}>Create User</button>
      </div>
    )}
  </Mutation>
);

在上面的代码中,我们定义了一个CREATE_USER的GraphQL变更,并将其作为mutation属性传递给Mutation组件。在组件的回调函数中,我们可以通过调用createUserrrreee

위 코드에서는 GET_USER에 대한 GraphQL 쿼리를 정의하고 이를 query 속성으로 Query에 전달합니다. 요소. 또한 variables 속성을 ​​통해 쿼리에 필요한 변수를 전달했습니다. 구성요소의 콜백 함수에서는 로드, 오류, 데이터와 같은 정보에 액세스할 수 있습니다. 이 정보를 바탕으로 페이지에 해당 콘텐츠를 표시할 수 있습니다.

    GraphQL 변경 사항 보내기

    쿼리 보내기 외에도 Apollo Client에서 제공하는 Mutation 구성 요소를 사용하여 GraphQL 변경 사항을 보낼 수도 있습니다. 예는 다음과 같습니다.

    rrreee🎜 위 코드에서는 CREATE_USER의 GraphQL 변형을 정의하고 이를 Mutationmutation 속성으로 전달합니다. 요소. 구성 요소의 콜백 함수에서 createUser 함수를 호출하여 변경 사항을 보낼 수 있습니다. 마찬가지로 필요에 따라 페이지에 관련 콘텐츠를 표시할 수 있습니다. 🎜🎜3. 요약🎜🎜위의 예를 통해 React와 GraphQL의 결합으로 효율적이고 유연하며 확장 가능한 프런트엔드 및 백엔드 데이터 상호 작용을 달성할 수 있음을 알 수 있습니다. React와 Apollo Client를 사용하면 GraphQL 쿼리와 변경 사항을 쉽게 보내고, 페이지에 데이터를 표시하고 처리할 수 있습니다. 이 접근 방식은 프런트 엔드 개발의 복잡성을 크게 단순화하고 더 나은 사용자 경험을 제공할 수 있습니다. 🎜🎜이 기사가 React 및 GraphQL을 사용하여 유연한 프런트엔드 및 백엔드 데이터 상호 작용을 구축하는 방법을 이해하는 데 도움이 되기를 바랍니다. 아직 React와 GraphQL을 사용해보지 않으셨다면, 자신의 프로젝트에서 사용해 보시기 바랍니다. 이 두 가지가 얼마나 강력한지 알게 되실 것입니다. 웹 개발에서 더 나은 결과를 기원합니다! 🎜

위 내용은 React와 GraphQL을 사용하여 유연한 프런트엔드 및 백엔드 데이터 상호 작용을 구축하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.