GraphQL is a modern API query language that is widely used in modern web applications because it provides an efficient, flexible and powerful way to obtain data
GraphQL basic quick application example:
1. Backend settings (using graphql-yoga)
First, we need to create a GraphQL server. Install graphql-yoga and create a simple GraphQL schema:
npm init -y npm install graphql yoga graphql-yoga # server.js const { GraphQLServer } = require('graphql-yoga'); const typeDefs = ` type Query { hello: String } type Mutation { addMessage(message: String!): String } `; const resolvers = { Query: { hello: () => 'Hello world!', }, Mutation: { addMessage: (_, { message }) => `You added the message "${message}"`, }, }; const server = new GraphQLServer({ typeDefs, resolvers }); server.start(() => console.log(`Server is running on http://localhost:4000`));
2. Front-end setup (using Apollo Client)
Next, we need to configure Apollo Client in the front-end application to communicate with our GraphQL server:
npm install apollo-boost @apollo/client graphql # client.js import ApolloClient from 'apollo-boost'; import { InMemoryCache } from '@apollo/client'; const client = new ApolloClient({ uri: 'http://localhost:4000/graphql', cache: new InMemoryCache(), }); export default client;
3. Write front-end components
Now, we use Apollo Client in the React component to perform queries and mutations:
// App.js import React from 'react'; import { gql, useQuery, useMutation } from '@apollo/client'; import client from './client'; const GET_HELLO = gql` query GetHello { hello } `; const ADD_MESSAGE_MUTATION = gql` mutation AddMessage($message: String!) { addMessage(message: $message) } `; function App() { const { loading, error, data } = useQuery(GET_HELLO); const [addMessage, { data: mutationData }] = useMutation(ADD_MESSAGE_MUTATION); if (loading) return <p>Loading...</p>; if (error) return <p>Error :(</p>; return ( <div> <h1 id="data-hello">{data.hello}</h1> <button onclick="{()"> addMessage({ variables: { message: 'Hello from frontend!' } })}> Add Message </button> {mutationData && <p>New message: {mutationData.addMessage}</p>} </div> ); } export default App;
We create a GET_HELLO query to get the server's greeting and display it on the page. At the same time, we define an ADD_MESSAGE_MUTATION mutation operation, which will send a new message to the server when the user clicks the button.
4. Run the application
Start the backend server:
node server.js
Then start the frontend application, assuming Create React App:
npm start
GraphQL Basic Queries
1. Query Language: Queries, Mutations, Subscriptions
In GraphQL, queries and mutations are strings represented by JSON-like structures. Here is a simple example:
# Query Example query GetUser { user(id: 1) { name email } } # Mutation Example mutation CreateUser { createUser(name: "Alice", email: "alice@example.com") { id name } } # Subscription Example (Assuming WebSocket) subscription OnNewUser { newUser { id name } }
In the above code, the GetUser query requests the name and email of the user with user ID 1. The CreateUser mutation creates a new user and returns the new user's ID and name. The OnNewUser subscription waits for the new user to be created and returns the new user's information.
2. Type System
On the backend, we define a GraphQL schema to describe these types:
type User { id: ID! name: String! email: String! } type Mutation { createUser(name: String!, email: String!): User } type Subscription { newUser: User }
Here we define a User object type, a Mutation type for mutation operations, and a Subscription type for subscription operations.
3. Query structure: fields and parameters
The query structure consists of fields and parameters. In the query example above, user is the field, and id and email are subfields of the user field. Parameters such as id: 1 are used to customize the query.
4. Hierarchy and nesting
GraphQL queries can be nested. Here is a more complex example:
query GetUsersAndPosts { users { id name posts { id title content author { id name } } } }
This query requests all users and their respective posts, which also include information about the author. Hierarchies allow multiple levels of data to be retrieved in one request.
Client Code Example (Using Apollo Client)
npm init -y npm install graphql yoga graphql-yoga # server.js const { GraphQLServer } = require('graphql-yoga'); const typeDefs = ` type Query { hello: String } type Mutation { addMessage(message: String!): String } `; const resolvers = { Query: { hello: () => 'Hello world!', }, Mutation: { addMessage: (_, { message }) => `You added the message "${message}"`, }, }; const server = new GraphQLServer({ typeDefs, resolvers }); server.start(() => console.log(`Server is running on http://localhost:4000`));
In this React component, we use useQuery to fetch data from a GraphQL server and render information about users and their posts. This is how GraphQL queries, type systems, and hierarchies come into play.
GraphQL Schema
GraphQL Schema Definition Language (SDL) is a language for describing GraphQL schemas. It defines data types, queries, mutations, and directives in a concise, human-readable format.
Define types
First, let's define some basic data types. For example, define a User type and a Post type.
npm install apollo-boost @apollo/client graphql # client.js import ApolloClient from 'apollo-boost'; import { InMemoryCache } from '@apollo/client'; const client = new ApolloClient({ uri: 'http://localhost:4000/graphql', cache: new InMemoryCache(), }); export default client;
Here, the User type has id, username, email fields, and a posts field that links to multiple Posts. The Post type contains id, title, content fields, and an author field that points to the User.
Query root and mutation root
Next, define the GraphQL query root (Query) and mutation root (Mutation) types, which are the entry points for clients to request data and modify data.
// App.js import React from 'react'; import { gql, useQuery, useMutation } from '@apollo/client'; import client from './client'; const GET_HELLO = gql` query GetHello { hello } `; const ADD_MESSAGE_MUTATION = gql` mutation AddMessage($message: String!) { addMessage(message: $message) } `; function App() { const { loading, error, data } = useQuery(GET_HELLO); const [addMessage, { data: mutationData }] = useMutation(ADD_MESSAGE_MUTATION); if (loading) return <p>Loading...</p>; if (error) return <p>Error :(</p>; return ( <div> <h1 id="data-hello">{data.hello}</h1> <button onclick="{()"> addMessage({ variables: { message: 'Hello from frontend!' } })}> Add Message </button> {mutationData && <p>New message: {mutationData.addMessage}</p>} </div> ); } export default App;
In the Query type, we define queries for getting a single user, all users, a single post, and all posts. In the Mutation type, we define operations for creating new users and new posts.
Understanding and using Directives
Directives are instructions in the GraphQL schema that change execution behavior. They can be applied to any part of the type system definition, such as fields, input types, object types, etc. The following shows how to use a custom @auth directive to control access rights.
First, suppose we define an @auth directive to restrict access to certain fields and require users to log in.
node server.js
Next, apply this directive in the schema:
npm start
In the above example, the me query and username field can be accessed without special permissions, but accessing the user's email field requires administrator permissions (specified by the @auth(requires: ADMIN) directive).
GraphQL Advanced Applications
1. Pagination
Use GraphQL Cursor-based pagination to improve performance and user experience.
Schema definition:
# Query Example query GetUser { user(id: 1) { name email } } # Mutation Example mutation CreateUser { createUser(name: "Alice", email: "alice@example.com") { id name } } # Subscription Example (Assuming WebSocket) subscription OnNewUser { newUser { id name } }
Resolver example:
type User { id: ID! name: String! email: String! } type Mutation { createUser(name: String!, email: String!): User } type Subscription { newUser: User }
2. Error handling
Customize error handling to improve the client's ability to handle errors.
Resolver example:
query GetUsersAndPosts { users { id name posts { id title content author { id name } } } }
3. Custom directives
Create custom directives to implement specific business logic or security requirements.
Schema definition:
import { gql, useQuery } from '@apollo/client'; const GET_USERS_AND_POSTS = gql` query GetUsersAndPosts { users { id name posts { id title content author { id name } } } } `; function App() { const { loading, error, data } = useQuery(GET_USERS_AND_POSTS); if (loading) return <p>Loading...</p>; if (error) return <p>Error :-(</p>; return ( <div> {data.users.map(user => ( <div key="{user.id}"> <h2 id="user-name">{user.name}</h2> <ul> {user.posts.map(post => ( <li key="{post.id}"> <h3 id="post-title">{post.title}</h3> <p>{post.content}</p> <p>Author: {post.author.name}</p> </li> ))} </ul> </div> ))} </div> ); } export default App;
Resolver example:
type User { id: ID! username: String! email: String! posts: [Post!]! } type Post { id: ID! title: String! content: String! author: User! }
Make sure to register this directive handler in your GraphQL server configuration.
4. GraphQL Federation
Federation allows building a single GraphQL API composed of multiple services.
Service A Schema:
npm init -y npm install graphql yoga graphql-yoga # server.js const { GraphQLServer } = require('graphql-yoga'); const typeDefs = ` type Query { hello: String } type Mutation { addMessage(message: String!): String } `; const resolvers = { Query: { hello: () => 'Hello world!', }, Mutation: { addMessage: (_, { message }) => `You added the message "${message}"`, }, }; const server = new GraphQLServer({ typeDefs, resolvers }); server.start(() => console.log(`Server is running on http://localhost:4000`));
Service B Schema:
npm install apollo-boost @apollo/client graphql # client.js import ApolloClient from 'apollo-boost'; import { InMemoryCache } from '@apollo/client'; const client = new ApolloClient({ uri: 'http://localhost:4000/graphql', cache: new InMemoryCache(), }); export default client;
5. Complex query optimization
Use GraphQL's field resolver and data loader to optimize performance.
Data Loader example:
// App.js import React from 'react'; import { gql, useQuery, useMutation } from '@apollo/client'; import client from './client'; const GET_HELLO = gql` query GetHello { hello } `; const ADD_MESSAGE_MUTATION = gql` mutation AddMessage($message: String!) { addMessage(message: $message) } `; function App() { const { loading, error, data } = useQuery(GET_HELLO); const [addMessage, { data: mutationData }] = useMutation(ADD_MESSAGE_MUTATION); if (loading) return <p>Loading...</p>; if (error) return <p>Error :(</p>; return ( <div> <h1 id="data-hello">{data.hello}</h1> <button onclick="{()"> addMessage({ variables: { message: 'Hello from frontend!' } })}> Add Message </button> {mutationData && <p>New message: {mutationData.addMessage}</p>} </div> ); } export default App;
GraphQL Features and Advantages
- Performance optimization: By obtaining data on demand, network transmission overhead is reduced and page loading speed is improved.
- Reduce errors: The client defines the query structure, and the server returns the expected shape, reducing errors caused by interface mismatch.
- Better API design: The strong type system ensures the consistency and correctness of the data, making the API easier to understand and maintain.
- Client control: The client can decide how much data to obtain and when to obtain it, which improves the user experience.
- Cache optimization: The client can more easily implement caching strategies based on the returned data structure.
- Reduce backend complexity: The backend no longer needs to create multiple API endpoints to meet the needs of different clients.
The above is the detailed content of Applications and Advantages of GraphQL in Modern Web Applications. For more information, please follow other related articles on the PHP Chinese website!

JavaScript can be used for front-end and back-end development. The front-end enhances the user experience through DOM operations, and the back-end handles server tasks through Node.js. 1. Front-end example: Change the content of the web page text. 2. Backend example: Create a Node.js server.

Choosing Python or JavaScript should be based on career development, learning curve and ecosystem: 1) Career development: Python is suitable for data science and back-end development, while JavaScript is suitable for front-end and full-stack development. 2) Learning curve: Python syntax is concise and suitable for beginners; JavaScript syntax is flexible. 3) Ecosystem: Python has rich scientific computing libraries, and JavaScript has a powerful front-end framework.

The power of the JavaScript framework lies in simplifying development, improving user experience and application performance. When choosing a framework, consider: 1. Project size and complexity, 2. Team experience, 3. Ecosystem and community support.

Introduction I know you may find it strange, what exactly does JavaScript, C and browser have to do? They seem to be unrelated, but in fact, they play a very important role in modern web development. Today we will discuss the close connection between these three. Through this article, you will learn how JavaScript runs in the browser, the role of C in the browser engine, and how they work together to drive rendering and interaction of web pages. We all know the relationship between JavaScript and browser. JavaScript is the core language of front-end development. It runs directly in the browser, making web pages vivid and interesting. Have you ever wondered why JavaScr

Node.js excels at efficient I/O, largely thanks to streams. Streams process data incrementally, avoiding memory overload—ideal for large files, network tasks, and real-time applications. Combining streams with TypeScript's type safety creates a powe

The differences in performance and efficiency between Python and JavaScript are mainly reflected in: 1) As an interpreted language, Python runs slowly but has high development efficiency and is suitable for rapid prototype development; 2) JavaScript is limited to single thread in the browser, but multi-threading and asynchronous I/O can be used to improve performance in Node.js, and both have advantages in actual projects.

JavaScript originated in 1995 and was created by Brandon Ike, and realized the language into C. 1.C language provides high performance and system-level programming capabilities for JavaScript. 2. JavaScript's memory management and performance optimization rely on C language. 3. The cross-platform feature of C language helps JavaScript run efficiently on different operating systems.

JavaScript runs in browsers and Node.js environments and relies on the JavaScript engine to parse and execute code. 1) Generate abstract syntax tree (AST) in the parsing stage; 2) convert AST into bytecode or machine code in the compilation stage; 3) execute the compiled code in the execution stage.


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

Video Face Swap
Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Article

Hot Tools

DVWA
Damn Vulnerable Web App (DVWA) is a PHP/MySQL web application that is very vulnerable. Its main goals are to be an aid for security professionals to test their skills and tools in a legal environment, to help web developers better understand the process of securing web applications, and to help teachers/students teach/learn in a classroom environment Web application security. The goal of DVWA is to practice some of the most common web vulnerabilities through a simple and straightforward interface, with varying degrees of difficulty. Please note that this software

SAP NetWeaver Server Adapter for Eclipse
Integrate Eclipse with SAP NetWeaver application server.

Dreamweaver Mac version
Visual web development tools

Atom editor mac version download
The most popular open source editor

SublimeText3 Mac version
God-level code editing software (SublimeText3)
