Sphinx, reStructuredText показать/скрыть фрагменты кода
Я документировал программный пакет, используя Sphinx и ReStructuredText.
В моих документах есть некоторые фрагменты кода. Я хочу, чтобы они были скрыты по умолчанию, с небольшой кнопкой "Показать/Скрыть", которая расширила бы их (Example).
Есть ли стандартный способ сделать это?
Ответы
Ответ 1
Я думаю, что самый простой способ сделать это - создать пользовательскую тему Sphinx, в которой вы скажете определенным элементам html, чтобы иметь эту функциональность. Маленький JQuery проделает долгий путь здесь.
Если, однако, вы хотите указать это в своей разметке reStructuredText, вам нужно будет либо
- получить такую вещь, включенную в сам Сфинкс или
- реализовать его в расширении Sphinx/docutils... и затем создать тему Sphinx, которая знала об этой функциональности.
Это будет немного больше работы, но даст вам больше гибкости.
Ответ 2
Вам не нужна пользовательская тема. Используйте встроенный container
директив, который позволяет добавлять пользовательские css-классы в блоки и переопределять существующую тему, чтобы добавить некоторый javascript для добавления функции show/hide.
Это _templates/page.html
:
{% extends "!page.html" %}
{% block footer %}
<script type="text/javascript">
$(document).ready(function() {
$(".toggle > *").hide();
$(".toggle .header").show();
$(".toggle .header").click(function() {
$(this).parent().children().not(".header").toggle(400);
$(this).parent().children(".header").toggleClass("open");
})
});
</script>
{% endblock %}
Это _static/custom.css
:
.toggle .header {
display: block;
clear: both;
}
.toggle .header:after {
content: " ▶";
}
.toggle .header.open:after {
content: " ▼";
}
Это добавлено в conf.py
:
def setup(app):
app.add_stylesheet('custom.css')
Теперь вы можете показать/скрыть блок кода.
.. container:: toggle
.. container:: header
**Show/Hide Code**
.. code-block:: xml
:linenos:
from plone import api
...
Я использую что-то очень похожее для упражнений здесь: https://training.plone.org/5/mastering_plone/about_mastering.html#exercises
Ответ 3
Тема облачного сфинкса имеет пользовательскую директиву html-toggle
которая предоставляет переключаемые разделы. Цитировать с их веб-страницы:
Вы можете пометить разделы с помощью .. rst-class:: html-toggle
, что сделает раздел по умолчанию разделенным на html по умолчанию, с помощью ссылки переключения "show section" справа от заголовка.
Вот ссылка на их тестовую демонстрационную страницу.
Ответ 4
Существует очень упрощенное расширение, обеспечивающее именно эту функцию: https://github.com/scopatz/hiddencode
Это работает довольно хорошо для меня.