Structuring your API reference
Learn how to structure your API reference across multiple pages with icons and descriptions.
Last updated
Was this helpful?
Learn how to structure your API reference across multiple pages with icons and descriptions.
Last updated
Was this helpful?
Was this helpful?
GitBook does more than just render your OpenAPI spec. It lets you customize your API reference for better clarity, navigation, and branding.
To keep your documentation organized, GitBook can split your API operations into separate pages. Each page is generated from a tag in your OpenAPI spec. To group operations into a page, assign the same tag to each operation:
The order of pages in GitBook matches the order of tags in your OpenAPI tags array:
To build multi-level navigation, use x-parent
(or parent
) in tags to define hierarchy:
The above example will create a table of contents that looks like:
If a page has no description, GitBook will automatically show a card-based layout for its sub-pages.
You can enhance pages with titles, icons, and descriptions using custom extensions in the tags section. All Font Awesome icons are supported via x-page-icon
.
Tag description fields support GitBook markdown, including advanced blocks like tabs:
You can highlight a schema in a GitBook description by using GitBook markdown. Here is an example that highlights the “Pet” schema from the “petstore” specification:
paths:
/pet:
put:
tags:
- pet
summary: Update an existing pet.
description: Update an existing pet by Id.
operationId: updatePet
tags:
- name: everything
- name: pet
x-parent: everything
- name: store
x-parent: everything
Everything
├── Pet
└── Store
tags:
- name: pet
# Page title displayed in table of contents and page
-x-page-title: Pet
# Icon shown in table of contents and next to page title
-x-page-icon: dog
# Description shown just above the title
-x-page-description: Pets are amazing!
# Content of the page
description: Everything about your Pets
---
tags:
- name: pet
description: |
Here is the detail of pets.
{% tabs %}
{% tab title="Dog" %}
Here are the dogs
{% endtab %}
{% tab title="Cat" %}
Here are the cats
{% endtab %}
{% tab title="Rabbit" %}
Here are the rabbits
{% endtab %}
{% endtabs %}
---
tags:
- name: pet
description: |
{% openapi-schemas spec="petstore" schemas="Pet" grouped="false" %}
The Pet object
{% endopenapi-schemas %}
tags:
- name: pet
- name: store
- name: user