WordPressプラグイン「WPGraphQL」使用手順

GraphQLとは

GraphQLはAPIのためのクエリ言語(問い合わせ言語)

  1. 柔軟なデータ取得: クライアントが必要なデータのみを指定して取得できます。
  2. 単一エンドポイント: 複数のリソースを1回のリクエストで取得できます。
  3. 型システム: スキーマ定義により、APIの構造が明確になります。
  4. 効率的: オーバーフェッチ(過剰な取得)やアンダーフェッチを防ぎます。
  5. 進化しやすい: 既存のクエリを壊さずに新しいフィールドを追加できます。

GraphQLはRESTful APIの代替として注目されており、特にモバイルアプリケーションやコンプレックスなウェブアプリケーションで人気があります。

WordPressプラグイン「WPGraphQL」使用手順

WordPressのセットアップ

1)プラグイン「WPGraphQL」インストール

2)エンドポイントの設定(「GraphQL」→「Settings」)

Next.jsプロジェクトのセットアップ

1)Next.jsプロジェクトを作成

npx create-next-app@latest my-headless-wp
cd my-headless-wp

2)GraphQLクライアントをインストール

npm install @apollo/client graphql

3)Apollo Clientの設定

libフォルダを作成し、その中にapollo-client.tsファイルを作成します

\my-headless-wp\lib\apollo-client.ts

import { ApolloClient, InMemoryCache } from "@apollo/client";

export function getClient() {
  const client = new ApolloClient({
    uri: "https://あなたのサイト.com/graphql",
    cache: new InMemoryCache(),
  });

  return client;
}

▽「uri」はWordPress側で確認できます「GraphQL」→「Settings」

4)ApolloProvider の設定

app/components/ApolloWrapper.tsx
Apollo Client を設定し、React コンポーネントに Apollo Provider を提供するラッパーコンポーネントを定義しています。

'use client';

import { ApolloProvider } from "@apollo/client";
import { getClient } from "../../lib/apollo-client";

export default function ApolloWrapper({ children }: { children: React.ReactNode }) {
  const client = getClient();

  return <ApolloProvider client={client}>{children}</ApolloProvider>;
}

5)layout.tsxの編集

import ApolloWrapper from './components/ApolloWrapper';

export default function RootLayout({
  children,
}: {
  children: React.ReactNode;
}) {
  return (
    <html lang="en">
      <body>
        <ApolloWrapper>{children}</ApolloWrapper>
      </body>
    </html>
  );
}

\my-headless-wp\app\page.tsx

import Posts from "@/app/components/Posts";

export default function Home() {
  return (
    <main>
      <h1>My WordPress Blog</h1>
      <Posts />
    </main>
  );
}

\my-headless-wp\app\components\Posts.tsx
Apollo Client を使用して GraphQL クエリを実行し、取得したデータを表示する React コンポーネントを定義しています

'use client';

import { useQuery, gql } from "@apollo/client";

const GET_POSTS = gql`
  query GetPosts {
    posts {
      nodes {
        id
        title
        content
      }
    }
  }
`;

export default function Posts() {
  const { loading, error, data } = useQuery(GET_POSTS);

  if (loading) return <p>Loading...</p>;
  if (error) return <p>Error :(</p>;

  return (
    <>
      {data.posts.nodes.map((post: any) => (
        <div key={post.id}>
          <h2>{post.title}</h2>
          <div dangerouslySetInnerHTML={{ __html: post.content }} />
        </div>
      ))}
    </>
  );
}

参考サイト

【Next.js】WPGraphQLでWordPressをヘッドレスCMS化してみる
https://neightbor.jp/blog/nextjs-and-wordpress