Hide or remove content

It’s possible to control which content shows up in your book. For example, you may want to display a complex visualization to illustrate an idea, but don’t want the page to be cluttered with a large code cell that generated the viz. In other cases, you may want to remove a code cell entirely.

In this case, you have two options:

  • Hiding content provide a button that lets readers reveal the content.

  • Removing content prevents it from making it into your book. It will be entirely gone (though still present in the source files)

There are two ways to hide content:

  • To hide markdown, use the {toggle} directive.

  • To hide or remove code cells or their outputs, use notebook cell tags.

We’ll cover each below.

Hide markdown using MyST markdown

There are two ways to hide markdown content

  • you can use the {toggle} directive to hide arbitrary blocks of content

  • you can use the dropdown class to admonitions to turn them into dropdowns

Both allow you to wrap chunks of markdown in a button that lets users show and hide the content. We cover each below.

The {toggle} directive

You can activate this behavior in markdown with the {toggle} directive like so:

```{toggle}
Some hidden toggle content!

![](../images/cool.jpg)
```

This results in:

Some hidden toggle content!

Note that if you’d like to show the toggle content by default, you can add the :show: flag when you call {toggle}, like so:

```{toggle} Click the button to reveal!
:show:
Some hidden toggle content!

![](../images/cool.jpg)
```

Toggle admonition content with dropdowns

You can also add toggle buttons to admonition blocks, effectively making them dropdown blocks. Users will see the admonition title, but will need to click in order to reveal the content. To do so, add the dropdown class to any admonition. For example:

```{admonition} Click the button to reveal!
:class: dropdown
Some hidden toggle content!

![](../images/cool.jpg)
```

This results in:

See Hiding the content of admonitions for more information on admonition dropdowns.

Hide code cell content

You can hide most cell elements of a page. The sections below describe how to hide each using cell tags in MyST markdown. If you’re working with .ipynb files, see the cell tags guide on adding cell tags to notebooks in Jupyter Notebook or JupyterLab.

If an element is hidden, Jupyter Book will display a small button to the right of the old location for the hidden element. If a user clicks the button, the element will be displayed.

Hide cell inputs

If you add the tag hide-input to a cell, then Jupyter Book will hide the cell but display the outputs.

Here’s an example of cell metadata that would trigger the “hide code” behavior:

{
    "tags": [
        "hide-input",
    ]
}

For example, see the cell below contains the hide-input tag:

import numpy as np
import matplotlib.pyplot as plt
plt.ion()

data = np.random.randn(2, 100)
fig, ax = plt.subplots()
ax.scatter(*data, c=data[1], s=100*np.abs(data[0]));
../_images/hiding_1_0.png

Note how we only see the output by default. Now try clicking the button to the right of the empty spot above!

Hide cell outputs

You can also hide the outputs of a cell. For example, if you’d like to ask users to think about what the output will look like first before viewing an answer. To do so, add the following tag to your cell:

{
    "tags": [
        "hide-output",
    ]
}
# This cell should have its output hidden!
data = np.random.randn(2, 100)
fig, ax = plt.subplots()
ax.scatter(*data, c=data[1], s=100*np.abs(data[0]));
../_images/hiding_4_0.png

Hide entire code cells

If you’d like to hide the whole code cell (both inputs and outputs) just add each tag to the cell metadata, like so:

{
    "tags": [
        "hide-cell",
    ]
}
# This cell should have its output hidden!
data = np.random.randn(2, 100)
fig, ax = plt.subplots()
ax.scatter(*data, c=data[1], s=100*np.abs(data[0]));
../_images/hiding_6_0.png

Removing code cell content

In the above examples, we are only hiding the inputs, with the option that readers can reveal them if they wish. However, if you’d like to completely remove the inputs, so that their contents do not make it into the book’s HTML, you may use the following tag:

To remove the inputs of a cell:

{
    "tags": [
        "remove-input",
    ]
}

The following cell demonstrates removing inputs. Note that in this case, there is no button available to show the input contents, the entire input cell is gone!

Remove cell inputs

The following cell has its inputs removed

../_images/hiding_10_0.png

Remove cell outputs

Similar to hiding inputs, it is also possible to hide the outputs of a cell.

To remove the outputs of a cell:

{
    "tags": [
        "remove-output",
    ]
}

Remove an entire code cell

You can also remove both the inputs and outputs of a cell, in which case it won’t show up in your book at all. These cells remain in the notebook file itself, so they’ll show up if readers click on a JupyterHub or Binder link from a page.

To remove both the inputs and outputs of a cell, add the tag remove-cell to the tags of the cell. Here’s an example of cell metadata that would trigger the “remove cell” behavior:

{
    "tags": [
        "remove-cell",
    ]
}

These cells will be entirely removed from each book page - remember that if you’d like to optionally display the inputs of a cell instead, you should use the hide-input tag.

For example, there’s a cell below this one that won’t make it into the final book, because it has been removed!

Remove empty cells

You don’t need to do anything to remove empty cells from your pages. Jupyter Book will remove these automatically. Any cell with only whitespace will be removed.

For example, in the notebook for this page there are two cells above this one. One cell with whitespace, and another cell with a few line-breaks. Both are gone in the final output.