Django 富文本插件 mdeditor安裝和使用

django-mdeditor

Github地址:https://github.com/pylixm/django-mdeditor 歡迎試用,star收藏预麸!
Django-mdeditor 是基于 Editor.md 的一個 django Markdown 文本編輯插件應(yīng)用瞪浸。
Django-mdeditor 的靈感參考自偉大的項目 django-ckeditor.

功能

  • 支持 Editor.md 大部分功能
    • 支持標(biāo)準(zhǔn)的Markdown 文本、 CommonMark 和 GFM (GitHub Flavored Markdown) 文本;
    • 支持實時預(yù)覽吏祸、圖片上傳对蒲、格式化代碼、搜索替換贡翘、皮膚蹈矮、多語言等。
    • 支持TOC 目錄和表情鸣驱;
    • 支持 TeX, 流程圖泛鸟、時序圖等圖表擴展。
  • 可自定義 Editor.md 工具欄踊东。
  • 提供了 MDTextField 字段用來支持模型字段使用北滥。
  • 提供了 MDTextFormField 字段用來支持 FormModelForm.
  • 提供了 MDEditorWidget 字段用來支持 admin 自定義樣式使用。

快速入門

  • 安裝
pip install django-mdeditor
  • settings 配置文件 INSTALLED_APPS 中添加 mdeditor:
    INSTALLED_APPS = [
        ...
        'mdeditor',
    ]
  • settings 中添加媒體文件的路徑配置:
MEDIA_ROOT = os.path.join(BASE_DIR, 'uploads')
MEDIA_URL = '/media/'

在你項目根目錄下創(chuàng)建 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 來創(chuàng)建你的model 數(shù)據(jù)庫表.
  • 登錄 django admin后臺,點擊 '添加'操作坚冀,你會看到如下界面济赎。

[圖片上傳失敗...(image-511007-1566372330965)]

到此,你已經(jīng)初步體驗了 djang-mdeditor 遗菠,接下來詳細(xì)看下他的其他使用吧联喘。

用法說明

在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 對應(yīng)的字段轉(zhuǎn)為 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 = {
    'width': '90%',  # 自定義編輯框?qū)挾?    '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_floder': 'editor',  # 圖片保存文件夾名稱
    'theme': 'default',  # 編輯框主題 ,dark / default
    'preview_theme': 'default',  # 預(yù)覽區(qū)域主題啥辨, dark / default
    'editor_theme': 'default',  # edit區(qū)域主題涡匀,pastel-on-dark / default
    'toolbar_autofixed': True,  # 工具欄是否吸頂
    'search_replace': True,  # 是否開啟查找替換
    'emoji': True,  # 是否開啟表情功能
    'tex': True,  # 是否開啟 tex 圖表功能
    'flow_chart': True,  # 是否開啟流程圖功能
    'sequence': True  # 是否開啟序列圖功能
}

反饋交流

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市溉知,隨后出現(xiàn)的幾起案子陨瘩,更是在濱河造成了極大的恐慌腕够,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,509評論 6 504
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件舌劳,死亡現(xiàn)場離奇詭異帚湘,居然都是意外死亡,警方通過查閱死者的電腦和手機甚淡,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,806評論 3 394
  • 文/潘曉璐 我一進(jìn)店門大诸,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人贯卦,你說我怎么就攤上這事资柔。” “怎么了脸侥?”我有些...
    開封第一講書人閱讀 163,875評論 0 354
  • 文/不壞的土叔 我叫張陵建邓,是天一觀的道長。 經(jīng)常有香客問我睁枕,道長官边,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,441評論 1 293
  • 正文 為了忘掉前任外遇,我火速辦了婚禮注簿,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘跳仿。我一直安慰自己诡渴,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 67,488評論 6 392
  • 文/花漫 我一把揭開白布菲语。 她就那樣靜靜地躺著妄辩,像睡著了一般。 火紅的嫁衣襯著肌膚如雪山上。 梳的紋絲不亂的頭發(fā)上眼耀,一...
    開封第一講書人閱讀 51,365評論 1 302
  • 那天,我揣著相機與錄音佩憾,去河邊找鬼哮伟。 笑死,一個胖子當(dāng)著我的面吹牛妄帘,可吹牛的內(nèi)容都是我干的楞黄。 我是一名探鬼主播,決...
    沈念sama閱讀 40,190評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼抡驼,長吁一口氣:“原來是場噩夢啊……” “哼鬼廓!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起致盟,我...
    開封第一講書人閱讀 39,062評論 0 276
  • 序言:老撾萬榮一對情侶失蹤碎税,失蹤者是張志新(化名)和其女友劉穎柏副,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體蚣录,經(jīng)...
    沈念sama閱讀 45,500評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡割择,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,706評論 3 335
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了萎河。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片荔泳。...
    茶點故事閱讀 39,834評論 1 347
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖虐杯,靈堂內(nèi)的尸體忽然破棺而出玛歌,到底是詐尸還是另有隱情,我是刑警寧澤擎椰,帶...
    沈念sama閱讀 35,559評論 5 345
  • 正文 年R本政府宣布支子,位于F島的核電站,受9級特大地震影響达舒,放射性物質(zhì)發(fā)生泄漏值朋。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 41,167評論 3 328
  • 文/蒙蒙 一巩搏、第九天 我趴在偏房一處隱蔽的房頂上張望昨登。 院中可真熱鬧,春花似錦贯底、人聲如沸丰辣。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,779評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽笙什。三九已至,卻和暖如春胚想,著一層夾襖步出監(jiān)牢的瞬間琐凭,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,912評論 1 269
  • 我被黑心中介騙來泰國打工顿仇, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留淘正,地道東北人摆马。 一個月前我還...
    沈念sama閱讀 47,958評論 2 370
  • 正文 我出身青樓臼闻,卻偏偏與公主長得像,于是被迫代替她去往敵國和親囤采。 傳聞我的和親對象是個殘疾皇子述呐,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,779評論 2 354

推薦閱讀更多精彩內(nèi)容