django-mdeditor-富文本编辑器集成

引言:

在当今信息爆炸的时代,文字作为沟通的重要媒介,扮演着无可替代的角色。随着网络技术的不断发展,富文本编辑器的重要性也愈发凸显。富文本编辑器作为一款领先的编辑工具,为用户提供了丰富的功能和便捷的操作体验。无论是撰写文章、编辑博客,还是制作网页、发表论文,富文本编辑器都能满足用户对于编辑工具的各种需求。本文将带领读者深入探索富文本编辑器的功能和特点,解锁文字创作的新境界。

Django-mdeditor 是基于 Editor.md 的一个 django Markdown 文本编辑插件应用。

Django-mdeditor 的灵感参考自伟大的项目 django-ckeditor.

注:

  • 关于Markdown页面渲染问题,建议后端渲染。因Editor.md 已长时间不更新有些bug和兼容性问题需要自己调试,当然前端同学可自行选择。
  • 关于Jquery冲突问题,因admin后端需要,无法删除。建议将编辑页面单独一页或直接单独全屏一页,使用自己单独的静态文件,与其他页面区分。

功能

  • 支持 Editor.md 大部分功能
    • 支持标准的Markdown 文本、 CommonMark 和 GFM (GitHub Flavored Markdown) 文本;
    • 支持实时预览、图片上传、格式化代码、搜索替换、皮肤、多语言等。
    • 支持TOC 目录和表情;
    • 支持 TeX, 流程图、时序图等图表扩展。
  • 可自定义 Editor.md 工具栏。
  • 提供了 MDTextField 字段用来支持模型字段使用。
  • 提供了 MDTextFormField 字段用来支持 FormModelForm.
  • 提供了 MDEditorWidget 字段用来支持 admin 自定义样式使用。

快速入门

  • 安装
    pip install django-mdeditor
  • settings 配置文件 INSTALLED_APPS 中添加 mdeditor:
    INSTALLED_APPS = [
        ...
        'mdeditor',
    ]
  • 针对django3.0+修改 frame 配置,如下:
X_FRAME_OPTIONS = 'SAMEORIGIN'  # django 3.0 + 默认为 deny
  • settings 中添加媒体文件的路径配置:
MEDIA_ROOT = os.path.join(BASE_DIR, 'uploads')
MEDIA_URL = '/media/'

在你项目根目录下创建 uploads/editor 目录,用于存放上传的图片。

  • 在你项目的根 urls.py 中添加扩展url和媒体文件url:
from django.conf.urls import url, include
from django.conf.urls.static import static
from django.conf import settings
...

urlpatterns = [
    ...
    url(r'mdeditor/', include('mdeditor.urls'))
]

if settings.DEBUG:
    # static files (images, css, javascript, etc.)
    urlpatterns += static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT)
  • 编写一个测试 model :
from django.db import models
from mdeditor.fields import MDTextField

class ExampleModel(models.Model):
    name = models.CharField(max_length=10)
    content = MDTextField()
  • admin.py 中注册model:
from django.contrib import admin
from . import models

admin.site.register(models.ExampleModel)
  • 运行 python manage.py makemigrationspython manage.py migrate 来创建你的model 数据库表.
  • 登录 django admin后台,点击 ‘添加’操作,你会看到如下界面。
django-mdeditor-富文本编辑器集成

到此,你已经初步体验了 djang-mdeditor ,接下来详细看下他的其他使用吧。

用法说明

在model 中使用 Markdown 编辑字段

在model 中使用 Markdown 编辑字段,我们只需要将 model 的TextField 替换成MDTextField 即可。

from django.db import models
from mdeditor.fields import MDTextField

class ExampleModel(models.Model):
    name = models.CharField(max_length=10)
    content = MDTextField()

在后台admin中,会自动显示 markdown 的编辑富文本。

在前端 template 中使用时,可以这样用:

{% load staticfiles %}
<!DOCTYPE html>
<html lang="zh">
    <head>
        <meta http-equiv="Content-Type" content="text/html; charset=utf-8" />

    </head>
    <body>
        <form method="post" action="./">
            {% csrf_token %}
            {{ form.media }}
            {{ form.as_p }}
            <p><input type="submit" value="post"></p>
        </form>
    </body>
</html>

在 Form 中使用 markdown 编辑字段

在 Form 中使用 markdown 编辑字段,使用 MDTextFormField 代替 forms.CharField, 如下:

from mdeditor.fields import MDTextFormField

class MDEditorForm(forms.Form):
    name = forms.CharField()
    content = MDTextFormField()

ModelForm 可自动将model 对应的字段转为 form字段, 可正常使用:

class MDEditorModleForm(forms.ModelForm):

    class Meta:
        model = ExampleModel
        fields = '__all__'

在 admin 中使用 markdown 小组件

在 admin 中使用 markdown 小组件,如下:

from django.contrib import admin
from django.db import models

# Register your models here.
from . import models as demo_models
from mdeditor.widgets import MDEditorWidget


class ExampleModelAdmin(admin.ModelAdmin):
    formfield_overrides = {
        models.TextField: {'widget': MDEditorWidget}
    }


admin.site.register(demo_models.ExampleModel, ExampleModelAdmin)

自定义工具栏

settings 中增加如下配置 :

MDEDITOR_CONFIGS = {
'default':{
    'width''90%',  # 自定义编辑框宽度
    'heigth'500,   # 自定义编辑框高度
    'toolbar': ["undo""redo""|",
                "bold""del""italic""quote""ucwords""uppercase""lowercase""|",
                "h1""h2""h3""h5""h6""|",
                "list-ul""list-ol""hr""|",
                "link""reference-link""image""code""preformatted-text""code-block""table""datetime",
                "emoji""html-entities""pagebreak""goto-line""|",
                "help""info",
                "||""preview""watch""fullscreen"],  # 自定义编辑框工具栏
    'upload_image_formats': ["jpg""jpeg""gif""png""bmp""webp"],  # 图片上传格式类型
    'image_folder''editor',  # 图片保存文件夹名称
    'theme''default',  # 编辑框主题 ,dark / default
    'preview_theme''default',  # 预览区域主题, dark / default
    'editor_theme''default',  # edit区域主题,pastel-on-dark / default
    'toolbar_autofixed'True,  # 工具栏是否吸顶
    'search_replace'True,  # 是否开启查找替换
    'emoji'True,  # 是否开启表情功能
    'tex'True,  # 是否开启 tex 图表功能
    'flow_chart'True,  # 是否开启流程图功能
    'sequence'True,  # 是否开启序列图功能
    'watch'True,  # 实时预览
    'lineWrapping'False,  # 自动换行
    'lineNumbers'False  # 行号
    }
}

总结

富文本编辑器不仅提供了强大的编辑功能,还注重用户体验和操作的便捷性。通过本文的介绍,我们深入了解了django-mdeditor富文本编辑器的各项功能和特点,从而更好地利用这一工具进行创作和编辑。欢迎关注山猫,👇



原文始发于微信公众号(python学习之旅):django-mdeditor-富文本编辑器集成

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

文章由极客之音整理,本文链接:https://www.bmabk.com/index.php/post/282712.html

(0)
青莲明月的头像青莲明月

相关推荐

发表回复

登录后才能评论
极客之音——专业性很强的中文编程技术网站,欢迎收藏到浏览器,订阅我们!