本文實例講述了Django框架使用富文本編輯器Uedit的方法。分享給大家供大家參考,具體如下:
Uedit是百度一款非常好用的富文本編輯器
一、安裝及基本配置
官方GitHub(有詳細的安裝使用教程):https://github.com/zhangfisher/DjangoUeditor
1. settings.py
INSTALLED_APPS = [ ... 'DjangoUeditor', ...]
2. 配置urls
from django.conf.urls import url, includeurlpatterns = [# 富文本相關url url(r'^ueditor/', include('DjangoUeditor.urls')),]
3. 字段信息
在需要使用富文本的字段所在的models.py中
from DjangoUeditor.models import UEditorFieldclass Articles(models.Model): ... content = UEditorField(width=1200, height=600, imagePath="article/ueditor/", filePath="article/ueditor/",verbose_name=u"文章內容") ...
注意,在要使用ueditor的字段所在adminx.py的類中,添加
# 這樣就指定了course的detail字段使用ueditor富文本編輯器class ArticlesAdmin(object): ... style_fields = {"content":"ueditor"}
二、Ueditor插件制作
1. 插件代碼
在extra_apps.xadmin.plugins中新建ueditor.py
import xadminfrom xadmin.views import BaseAdminPlugin, CreateAdminView, ModelFormAdminView, UpdateAdminViewfrom DjangoUeditor.models import UEditorFieldfrom DjangoUeditor.widgets import UEditorWidgetfrom django.conf import settingsclass XadminUEditorWidget(UEditorWidget): def __init__(self, **kwargs): self.ueditor_options=kwargs self.Media.js = None super(XadminUEditorWidget, self).__init__(kwargs)class UeditorPlugin(BaseAdminPlugin): def get_field_style(self, attrs, db_field, style, **kwargs): if style == 'ueditor': if isinstance(db_field, UEditorField): widget = db_field.formfield().widget param = {} param.update(widget.ueditor_settings) param.update(widget.attrs) return {'widget': XadminUEditorWidget(**param)} return attrs def block_extrahead(self, context, nodes): js = '<script type="text/javascript" src="%s"></script>' % (settings.STATIC_URL + "ueditor/ueditor.config.js") js += '<script type="text/javascript" src="%s"></script>' % (settings.STATIC_URL + "ueditor/ueditor.all.min.js") nodes.append(js)xadmin.site.register_plugin(UeditorPlugin, UpdateAdminView)xadmin.site.register_plugin(UeditorPlugin, CreateAdminView)
2. xadmin中注冊插件
在extra_apps.xadmin.plugins.__init__.py中添加
PLUGINS = ( ... 'ueditor',)
友情提醒
在Django中使用富文本編輯器
在HTML頁面中,Django處于安全考慮,將文本內容默認轉義,我們需要關閉
來正常輸出我們的文章
{% autoescape off %}{{ article.abstract }}{% endautoescape %}
新聞熱點
疑難解答