What are Fragments in GraphQL?

In GraphQL, fragments are a powerful feature that allows you to define reusable pieces of a query. They enable you to share common fields across multiple queries or mutations, making your GraphQL operations more concise and maintainable. Fragments help avoid repetition and ensure consistency in the fields being requested.

Key Features of Fragments

  • Reusability: Fragments can be defined once and reused in multiple queries or mutations, reducing redundancy.
  • Maintainability: Changes to a fragment only need to be made in one place, making it easier to update your queries.
  • Clarity: Fragments can improve the readability of your queries by breaking them into smaller, more manageable pieces.

Defining a Fragment

A fragment is defined using the fragment keyword, followed by the fragment name and the type it applies to. Here’s a simple example of a fragment that retrieves common fields for a user:


fragment UserFields on User {
id
name
email
}

Using Fragments in Queries

Once a fragment is defined, it can be included in queries using the ...FragmentName syntax. Here’s how you can use the UserFields fragment in a query to fetch users:


{
users {
...User Fields
}
}

Complete Example with Fragments

Below is a complete example that demonstrates how to define and use fragments in a GraphQL query:


const { ApolloServer, gql } = require('apollo-server');

// Sample data
const users = [
{ id: '1', name: 'Alice', email: 'alice@example.com' },
{ id: '2', name: 'Bob', email: 'bob@example.com' },
];

// Define the schema
const typeDefs = gql`
type User {
id: ID!
name: String!
email: String!
}

type Query {
users: [User ]
}

fragment UserFields on User {
id
name
email
}
`;

// Define the resolvers
const resolvers = {
Query: {
users: () => users,
},
};

// Create the Apollo Server
const server = new ApolloServer({ typeDefs, resolvers });

// Start the server
server.listen().then(({ url }) => {
console.log(`🚀 Server ready at ${url}`);
});

Using Fragments in Multiple Queries

Fragments can also be used in multiple queries to ensure consistency. For example, if you want to fetch user details in different contexts, you can reuse the same fragment:


{
user1: user(id: "1") {
...User Fields
}
user2: user(id: "2") {
...User Fields
}
}

Conclusion

Fragments in GraphQL are a powerful tool for creating reusable pieces of queries, enhancing the maintainability and readability of your GraphQL operations. By defining fragments for common fields, you can reduce redundancy and ensure consistency across your queries. Understanding how to effectively use fragments is essential for building efficient and organized GraphQL APIs.