Py3 Django2.5 集成富文本DjangoUeditor

本文介绍如何将DjangoUeditor3集成到Django项目中,包括环境配置步骤、后台UEditorField字段创建方法及前端显示技巧,并解决widgets包无法引入的问题。

    DjangoUeditor是在Py2上开发的,DjangoUeditor3解决了对Py3的兼容性问题。但在使用表单功能,引入DjangoUeitor.forms.UEditorField时,会出现widgets包无法引入的问题。所以为了方便修改和项目的维护,我把DjangoUeditor做成项目自身的APP引入。

一、环境配置

    1.项目内创建DjangoUeditor app

        python manage.py startapp DjangoUeditor 

    2. 下载DjangoUeditor3到本地,解压。

    

    复制文件夹DjangoUeditor3-master\DjangoUeditor\static\ueditor到项目\static\下。

    复制DjangoUeditor3-master\DjangoUeditor\templates下文件到项目templates。

    复制DjangoUeditor3-master\DjangoUeditor\下其他文件到项目DjangoUeditor下。


    3.配置     

    settings.py, 

BASE_DIR = os.path.dirname(os.path.dirname(os.path.abspath(__file__)))

sys.path.insert(0,os.path.join(BASE_DIR,'apps'))
# 设置上传文件的路径
MEDIA_URL = "/media/"
MEDIA_ROOT=os.path.join(BASE_DIR,'media')
 INSTALLED_APPS = [
    'DjangoUeditor',        # 添加新建app到项目
 ]
 STATIC_URL = '/static/'    # 配置static路径
 STATICFILES_DIRS = [
     os.path.join(BASE_DIR, 'static'),
 ]

    url.py

urlpatterns = [
    path('admin/', admin.site.urls),
    path('ueditor/', include('DjangoUeditor.urls' )),
    path('', index, name = 'index'),

]
urlpatterns += static(settings.STATIC_URL, document_root=settings.STATIC_ROOT)
urlpatterns += static(settings.MEDIA_URL, document_root=settings.MEDIA_ROOT)

二、后台使用

1.创建UEditorField字段

引入DjangoUeditor.modelsl.UEditorField,用法与FileField类型。但会多一些可设的参数,网上很多,查找不难,需要注意的是,在设置文件或图片的路径时,如果引入日期,格式需要注意,用法与FileField的upload_to存在一定的区别,最好使用官方提到的指定函数的方法:

from django.db import models
from datetime import datetime
from DjangoUeditor.models import UEditorField

def getImagePath(model_name):
    return "course/%s/image/%d/%d/"%(model_name, datetime.now().month, datetime.now().day)

class Resource(models.Model):
    teletext = UEditorField(verbose_name='信息', imagePath=getImagePath('resource'), null=True, blank=True,
                            toolbars = "full", width=800, height=250)

2. admin.py内正常配置。


三、前端显示

富文本在数据库内保存的是html代码,前端取消掉转义,直接使用便可:

{% autoescape off %}
{{ course.teletext }}
{% endautoescape %}

四、前端引入富文本编辑框

正如官方所说,在表单中使用,与常规form没有差别,但因为兼容性问题,需要对DjangoUeditor\forms.py进行小的修改,否则会出现widgets包无法引入的问题。





DjangoUeditorUeditor封装为一个Django app,提供文件/图片等上传功能,提供UEditorField、UEditorWidget等封装类,简化UeditorDjango中的应用。注:DjangoPython世界影响最大的Web框架。 本模块帮助在Django应用中集成百度Ueditor HTML编辑器,DjangoPython世界最有影响力的web框架。 Ueditor HTML编辑器是百度开源的在线HTML编辑器,功能非常强大,像表格可以直接拖动调整单元格大小等。 更新历史 [2014-7-8] Ver:1.8.143 Fix:当admin使用inlines生成多实例时widget命名不正确的问题 [2014-6-27] Ver:1.7.143 Fix:解决在admin管理后台的使用问题。 增加year,month,day的上传路径变量 [2014-6-25] 由于Ueditor从1.4版本开始,API发生了非常大的改动和不兼容,导致DjangoUeditor上一个版本的升级后上传功能不能用等,因此 本次重新设计了API,后端上传的代码几乎完全重写了。 更新到1.5.143,即版本号为1.5,使用了Ueditor 1.4.3版本。 重新设计了UeditorWidget、UeditorField。 新增了自定义Ueditor按钮的功能 注意:本次升级与之前版本不兼容,但是在使用体验上差别不大。 [2014-6-16] 更新到Ueditor 1.4.3 [2014-5-15] 增加不过滤 script,style ,不自动转div为p的脚本 修复在django 1.6和python2.7下的警告 使用 json 代替 django 中的 simplejson 用content_type 代替原来的 mime_type [2014-5-7] 更新到Ueditor 1.3.6 BUGfix:更新UEditor文件夹名字,避免在linux出现找不到静态文件问题 添加一种样式,besttome, 希望大家喜欢 [2013-2-22] 更新到Ueditor 1.2.5 BUGfix:更新UEditor文件夹名字,避免在linux出现找不到静态文件问题 BUGfix:现在支持south更新了 针对csrf导致上传图片失败的问题,现在默认上传视图开启了csrf_exempt装饰 相关阅读 百度编辑器UEditor插件DjangoUeditor使用方法
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值