mkdocs-material/docs/reference/content-tabs.md

243 lines
5.0 KiB
Markdown
Raw Normal View History

2020-07-20 20:28:13 +03:00
---
template: overrides/main.html
---
# Content tabs
Sometimes, it's desirable to group alternative content under different tabs,
e.g. when describing how to access an API from different languages or
environments. Material for MkDocs allows for beautiful and functional tabs,
grouping code blocks and other content.
2020-07-20 20:28:13 +03:00
## Configuration
This configuration enables content tabs, and allows to nest arbirtrary content
inside content tabs, including code blocks and ... more content tabs! Add the
following lines to `mkdocs.yml`
2020-07-20 20:28:13 +03:00
``` yaml
markdown_extensions:
- pymdownx.superfences
- pymdownx.tabbed:
alternate_style: true
```
2020-07-20 20:28:13 +03:00
See additional configuration options:
2020-07-20 20:28:13 +03:00
- [SuperFences]
- [Tabbed]
2021-10-02 16:24:09 +03:00
[SuperFences]: ../setup/extensions/python-markdown-extensions.md#superfences
[Tabbed]: ../setup/extensions/python-markdown-extensions.md#tabbed
2021-10-02 16:24:09 +03:00
### Linked content tabs
2021-10-02 16:24:09 +03:00
[:octicons-heart-fill-24:{ .mdx-heart } Insiders][Insiders]{ .mdx-insiders } ·
:octicons-unlock-24: Feature flag ·
:octicons-beaker-24: Experimental ·
[:octicons-tag-24: insiders-2.9.0 ... present][Insiders]
2021-10-02 16:24:09 +03:00
When enabled, all content tabs across the whole documentation site will be
linked and switch to the same label when the user clicks on a tab. Add the
following lines to `mkdocs.yml`:
2021-10-02 16:24:09 +03:00
``` yaml
theme:
features:
- content.tabs.link
```
2021-10-02 16:24:09 +03:00
Content tabs are linked based on their label, not offset. This means that all
tabs with the same label will be activated when a user clicks a content tab
regardless of order inside a container. Furthermore, this feature is fully
integrated with [instant loading] and persisted across page loads.
2020-07-20 20:28:13 +03:00
=== "With linking"
2020-07-20 20:28:13 +03:00
[![With linking]][With linking]
2020-07-21 17:01:22 +03:00
=== "Without linking"
2020-07-21 17:01:22 +03:00
[![Without linking]][Without linking]
2020-07-21 17:01:22 +03:00
[Insiders]: ../insiders/index.md
[instant loading]: ../setup/setting-up-navigation.md#instant-loading
[With linking]: ../assets/screenshots/content-tabs-link.png
[Without linking]: ../assets/screenshots/content-tabs.png
2020-07-21 17:01:22 +03:00
2020-07-20 20:28:13 +03:00
## Usage
### Grouping code blocks
Code blocks are one of the primary targets to be grouped, and can be considered
a special case of content tabs, as tabs with a single code block are always
rendered without horizontal spacing.
_Example_:
```
=== "C"
``` c
#include <stdio.h>
int main(void) {
printf("Hello world!\n");
return 0;
}
```
=== "C++"
``` c++
#include <iostream>
int main(void) {
std::cout << "Hello world!" << std::endl;
return 0;
}
```
```
_Result_:
=== "C"
``` c
#include <stdio.h>
int main(void) {
printf("Hello world!\n");
return 0;
}
```
=== "C++"
``` c++
#include <iostream>
int main(void) {
std::cout << "Hello world!" << std::endl;
return 0;
}
```
### Grouping other content
When a content tab contains more than one code block, it is rendered with
horizontal spacing. Vertical spacing is never added, but can be achieved
by nesting tabs in other blocks.
_Example_:
```
=== "Unordered list"
2020-07-27 13:05:07 +03:00
* Sed sagittis eleifend rutrum
* Donec vitae suscipit est
* Nulla tempor lobortis orci
2020-07-20 20:28:13 +03:00
=== "Ordered list"
1. Sed sagittis eleifend rutrum
2. Donec vitae suscipit est
3. Nulla tempor lobortis orci
```
_Result_:
=== "Unordered list"
2020-07-27 13:05:07 +03:00
* Sed sagittis eleifend rutrum
* Donec vitae suscipit est
* Nulla tempor lobortis orci
2020-07-20 20:28:13 +03:00
=== "Ordered list"
1. Sed sagittis eleifend rutrum
2. Donec vitae suscipit est
3. Nulla tempor lobortis orci
### Embedded content
When [SuperFences] is enabled, content tabs can contain arbitrary nested
content, including further content tabs, and can be nested in other blocks like
[admonitions] or blockquotes:
2020-07-20 20:28:13 +03:00
2020-07-20 20:34:44 +03:00
_Example_:
``` markdown
2020-07-20 20:38:11 +03:00
!!! example
2020-07-20 20:34:44 +03:00
=== "Unordered List"
_Example_:
``` markdown
2020-07-27 13:05:07 +03:00
* Sed sagittis eleifend rutrum
* Donec vitae suscipit est
* Nulla tempor lobortis orci
2020-07-20 20:34:44 +03:00
```
_Result_:
2020-07-27 13:05:07 +03:00
* Sed sagittis eleifend rutrum
* Donec vitae suscipit est
* Nulla tempor lobortis orci
2020-07-20 20:34:44 +03:00
=== "Ordered List"
_Example_:
``` markdown
1. Sed sagittis eleifend rutrum
2. Donec vitae suscipit est
3. Nulla tempor lobortis orci
```
_Result_:
1. Sed sagittis eleifend rutrum
2. Donec vitae suscipit est
3. Nulla tempor lobortis orci
```
_Result_:
2020-07-20 20:38:11 +03:00
!!! example
2020-07-20 20:28:13 +03:00
2020-07-20 20:34:44 +03:00
=== "Unordered List"
2020-07-20 20:28:13 +03:00
_Example_:
``` markdown
2020-07-27 13:05:07 +03:00
* Sed sagittis eleifend rutrum
* Donec vitae suscipit est
* Nulla tempor lobortis orci
2020-07-20 20:28:13 +03:00
```
_Result_:
2020-07-27 13:05:07 +03:00
* Sed sagittis eleifend rutrum
* Donec vitae suscipit est
* Nulla tempor lobortis orci
2020-07-20 20:28:13 +03:00
2020-07-20 20:34:44 +03:00
=== "Ordered List"
2020-07-20 20:28:13 +03:00
_Example_:
``` markdown
1. Sed sagittis eleifend rutrum
2. Donec vitae suscipit est
3. Nulla tempor lobortis orci
```
_Result_:
1. Sed sagittis eleifend rutrum
2. Donec vitae suscipit est
3. Nulla tempor lobortis orci
[admonitions]: admonitions.md