В Django можно легко интегрировать Markdown
Установка необходимых библиотек
Сначала установим необходимые пакеты:
pip install django-markdownx
pip install markdownify
Настройка проекта
После установки пакетов, добавьте markdownx в список установленных приложений в файле settings.py:
INSTALLED_APPS = [
...,
'markdownx',
]
Также добавьте путь к обработчику медиа-файлов markdownx в urls.py:
urlpatterns = [
...,
path('markdownx/', include('markdownx.urls')),
]
Создание формы для редактирования Markdown
Измените форму AddPostForm, добавив поле для Markdown-контента:
from markdownx.fields import MarkdownxFormField
class AddPostForm(forms.ModelForm):
content = MarkdownxFormField()
cat = forms.ModelChoiceField(queryset=Category.objects.all(), label="Категория", empty_label="Категория не выбрана")
class Meta:
model = Note
fields = ['title', 'content', 'image', 'is_published', 'cat', 'tags']
widgets = {
'title': forms.TextInput(attrs={'class': 'form-input'}),
'content': forms.Textarea(attrs={'cols': 60, 'rows': 10}),
}
Отображение Markdown-контента в шаблоне
В шаблонах, где отображается контент статьи, используйте фильтр markdownify для рендеринга Markdown в HTML:
{% load markdownify %}
...
<div>
{{ note.content|markdownify }}
</div>
...
Дополнительные возможности
Если вы хотите добавить превью Markdown-контента в админ-панель, добавьте следующий код в файл admin.py:
from django.contrib import admin
from .models import Note
from markdownx.admin import MarkdownxModelAdmin
class NoteAdmin(MarkdownxModelAdmin):
pass
admin.site.register(Note, NoteAdmin)
Теперь вы сможете писать и редактировать статьи в Markdown прямо в админ-панели.
Ресурсы для изучения
Для углубленного изучения Markdown и его применения в Django, вот несколько полезных ресурсов:
Документация MarkdownX: https://neuman.ai/markdownx/
Markdown Cheat Sheet: https://www.markdownguide.org/cheat-sheet/
Django Documentation: https://docs.djangoproject.com/en/stable/ref/contrib/admin/
Эти ресурсы помогут вам освоить Markdown и успешно применять его в своих проектах на Django.