Last updated

Tabs Tag Redocly Custom Tag

The tabs tag places content into a series of tabs, providing a structure for you to organize multiple pieces of content within a confined space. Users switch between tabs to access different sections of information within the same interface.

Redocly's tab implementation is fully accessible for screen readers and keyboard navigation.

Syntax and usage

Add an opening and closing tabs tag to declare a tabs section.

{% tabs %}
{% /tabs %}

Wrap your content within a tab tag and provide a name using the label attribute. A tab only works as a child of a tabs section.

{% tabs %}
  {% tab label="Tab 1" %}
    Content for Tab 1
  {% /tab %}
  {% tab label="Tab 2" %}
    Content for Tab 2
  {% /tab %}
{% /tabs %}

Attributes

AttributeTypeDescription
labelstringREQUIRED. Sets the name of the tab.

Examples

Tabs are powerful and flexible, but easy to misuse. Only use them when there is a clear benefit to organizing content in this manner.

Please read the best practices section before using tabs in your documentation.

Organize content

Tabs can make it easier for users to find what they need. The following example uses tabs to group related information together:

{% tabs %}
  {% tab label="Web frameworks" %}
    * Django
    * Ruby on Rails
    * Angular
    * Vue
    * React
  {% /tab %}
  {% tab label="Cloud services" %}
    * AWS
    * Google Cloud
    * Microsoft Azure
    * Cloudflare
  {% /tab %}
{% /tabs %}
  • Django
  • Ruby on Rails
  • Angular
  • Vue
  • React

Present different views

Tabs can be used to switch between different views of the same content. The following example uses tabs to display a list view and table view of the same content:

{% tabs %}
  {% tab label="List view " %}
    * Web Frameworks
      * Django
      * Ruby on Rails
      * Angular
      * Vue
      * React
    * Cloud services
      * AWS
      * Google Cloud
      * Microsoft Azure
      * Cloudflare
  {% /tab %}
  {% tab label="Table view" %}
    {% table %}
      - Category
      - Technologies
      ---
      - Web Frameworks
      - Django, Ruby on Rails, Angular, Vue, React
      ---
      - Cloud services
      - AWS, Google Cloud, Microsoft Azure, Cloudflare
    {% /table %}
  {% /tab %}
{% /tabs %}
  • Web Frameworks
    • Django
    • Ruby on Rails
    • Angular
    • Vue
    • React
  • Cloud services
    • AWS
    • Google Cloud
    • Microsoft Azure
    • Cloudflare

Showcase features

Tabs can be used to showcase different features. The following example uses tabs to showcase the different ways of configuring the feedback element in Redocly:

{% tabs %}
  {% tab label="Comment" %}
    The following settings allow users to leave comments when providing feedback:

    ```yaml {% title="redocly.yaml" %}
    feedback:
      type: comment
      settings:
        label: Please leave a couple of words here about your experience.
        submitText: Your comment has been sent to our team!
    ```
  {% /tab %}
  {% tab label="Star rating" %}
    The following settings changes the feedback element to rate pages by number of stars:

    ```yaml {% title="redocly.yaml" %}
    feedback:
      type: rating
      settings:
        label: How many stars for this page?
        submitText: Thank you for your stars!
    ```
  {% /tab %}
  {% tab label="Scale" %}
    The following settings configure the feedback element as a scale:

    ```yaml {% title="redocly.yaml" %}
    feedback:
      type: scale
      settings:
        label: Do you like our page?
        submitText: Thanks for your feedback!
        leftScaleLabel: Not helpful
        rightScaleLabel: Very helpful
    ```
  {% /tab %}
{% /tabs %}

The following settings allow users to leave comments when providing feedback:

redocly.yaml
feedback:
  type: comment
  settings:
    label: Please leave a couple of words here about your experience.
    submitText: Your comment has been sent to our team!

Give users control

Tabs can be used to give users more control over the content they see. The following example uses tabs to group resources into beginner and advanced categories:

{% tabs %}
  {% tab label="Beginner CLI resources" %}
    * [Install Redocly CLI](/docs/cli/installation.md)
    * [Redocly CLI quickstart guide](/docs/cli/quickstart.md)
  {% /tab %}
  {% tab label="Advanced CLI resources" %}
    * [Hide internal APIs](/docs/cli/guides/hide-apis.md)
    * [Enforce response contents](/docs/cli/guides/response-contains-property.md)
  {% /tab %}
{% /tabs %}

Best practices

When deciding whether to use tabs, ask yourself "How does this structure add value for the reader?".

Use tabs strategically

Prioritize reader experience

Consider the reader's journey and how tabs can help guide them through the document effectively. Tabs should help organize complex information, highlight differences, or provide alternative perspectives.

Don't use as navigation

Tabs should provide different views within the same context. Don't use tabs to force users to navigate between pieces of content, especially when it's content they might need to see simultaneously. Using tabs in this way hurts usability and adds to your user's cognitive load.

Clarity over complexity

Use clear, concise tab names

Give your tabs short, readable labels and don't use all caps. Ensuring your tabs are scannable creates a better experience for readers.

Limit tab count

Keep the number of tabs low for better navigation and comprehension. Too many tabs is overwhelming for users and having multiple rows is a bad experience.