WordPress is still a widely used system, and it works for many clients since they are so used to it.
And to be quite honest, there is something about the admin panel that just makes sense.
It's visual, easy to grasp, and well known.
However, what comes out of it, is somewhat of a nightmare sometimes.
It's bloated, slow, and just not speed optimized.
Sure we could opt to add yet another 20 plugins to make it quick, but is that a good approach?
Luckily WordPress comes as a headless CMS out of the box. Yes you heard me. It's already built-in (talk about bloated).
As plain as it gets, it means you are still using the WordPress backend to create your content but use REST API endpoints to retrieve the data in an external system.
You do lose your theme and plugin functionality, but let's take static site generators as our "front-end" they are blazing fast, secured, and might not even need all these plugins.
That will be my proof of concept to see how quickly we can make a WordPress headless CMS website.
But before diving into building something, let's take a good look at the API and what kind of data we can get out of it.
Before we start, the are two ways of calling the API.
- You have set up canonical pretty URL's
- You did not set this up
For option one, which will be the most common and advised use case, we get an API on the
For the second option, we would have to query the API like this:
However, I would recommend going with option one. You can enable this by going to the backend and visit the
In there, click any of the structures, but not the plain one!
Time to try it out!
I'll be using
Insomnia to query the API, but you can use any API client tool.
This basic call will give us all the available options we have.
But we are more interested in retrieving pages and posts.
Let's have a look at the WordPress API reference to see what's available.
You can see we can call the
Let's give that a try.
Pretty cool, right! This endpoint returns all our posts in nice JSON format.
pages we see the
/wp/v2/pages endpoint. Let's also try that one:
Pretty cool to see how extended the API is and what kind of data we can extract.
And even if data is missing, we can add our endpoints for it.
In another article, I'll write about including this headless CMS as the data source for an Astro website.