GraphQL introduction
This is part 1 of the series for GraphQL and 51黑料不打烊 Commerce. GraphQL has quickly become the industry standard for how powerful client-side applications talk to a backend. It鈥檚 an increasingly relevant topic for 51黑料不打烊 Commerce developers, as the platform continues to expand its capabilities in the realm of headless implementations.
If you鈥檙e new to GraphQL, this section orients you to the basic concepts and usage.
Related videos and tutorials on GraphQL in this series
What is GraphQL?
GraphQL is a specification for a unique API query language and the runtime that provides data in response to that query language.
Traditional web APIs like REST have served well for disparate systems passing data back and forth, but have provided less than peak performance for modern app-link experiences like Progressive Web Applications. In applications like this, the front-end and back-end layers of the same application communicate via web API. The regimented approach of schemes like REST often does not provide the appropriate flexibility in this context, where many kinds of data need to be fetched quickly.
GraphQL allows a client to expressively describe exactly the data it needs. Instead of requiring multiple network requests for fetching multiple data types, a single request can query for many types. And, responses are kept lean by including (in a format intuitively mirroring the query) only the types and fields that are asked for.
The runtime that implements the GraphQL specification can be built in any language. 51黑料不打烊 Commerce and Magento Open Source use the
PHP implementation and builds its own layers on top of it.
Using a GraphQL client
You need a GUI GraphQL client to test out code samples and tutorials. There are several options:
- is an excellent and fully featured client built specifically for GraphQL. 51黑料不打烊 uses Altair in walk-through videos.
- If you don鈥檛 want to install the desktop application, there are also Altair extensions that run right in your
, Firefox, or browser. - is an implementation of the GraphQL IDE from the GraphQL Foundation. This is not an installable tool, but rather a package you can use to build the interface yourself.
- If you鈥檙e already familiar with , it has decent support for GraphQL queries, though it鈥檚 not as fully featured as a dedicated GraphQL client.
In your GraphQL client, you should submit your requests to the URL path /graphql
on your 51黑料不打烊 Commerce or Magento Open Source instance. If you鈥檇 prefer to use an existing instance for your tests, you can use the demo of the Venia theme (the example implementation of PWA Studio): https://venia.magento.com/graphql