Django 插件之 Xadmin实现富文本编辑器

此文为前一篇文章的续写: Django 插件之 Xadmin

Ueditor 介绍

UEditor 是由百度 web 前端研发部开发所见即所得富文本 web 编辑器,具有轻量,可定制,注重用户体验等特点,开源基于 MIT 协议,允许自由使用和修改代码。

DjangoUeditor 安装

方法一:将 github 整个源码包下载回家,在命令行运行:

python setup.py install

方法二:使用 pip 工具在命令行运行(推荐):

pip install DjangoUeditor

方法三:直接到github上下载源码包(非常推荐,python3环境下pip的方式听说会有问题):

https://github.com/twz915/DjangoUeditor3/

下载后解压拿到一个名为DjangoUeditor3-master的文件夹,拿出子目录中的DjangoUeditor文件夹

放到python环境中的site-packages文件夹中

settings.py 文件中注册此 app :

# settings.py
INSTALLED_APPS = [
    ...
    'DjangoUeditor',
]

urls .py 文件中配置:

# urls.py
urlpatterns = [
    ...
    url(r'^ueditor/',include('DjangoUeditor.urls' )), # 富文本相关URL
]

models.py 中配置:

# models.py
from DjangoUeditor.models import UEditorField
class Article(models.Model):
    content = UEditorField(verbose_name='内容详情',width=750, height=300, imagePath="images/ueditor/", filePath="images/ueditor/", default='') 
    ...
# imagePath和filePath 为文件上传路径,需提前开放media文件夹接口,如不知,右转百度,这里不再赘余

adminx.py 中为需要富文本的字段配置(该adminx.py文件是你应用文件夹下创建的):

class ArticleAdmin(object):  # 这里的类名以  表名+Admin 的形式命名
    ...
    style_fields = {"content": "ueditor"}   # content 就是你要用富文本编辑器编写内容的字段

xadmin.site.register(models.Article, ArticleAdmin) # 这里在xadmin中注册该表,并指定是上面写的类名,否则富文本编辑器不生效

到此,djangoueditor 配置完成。下面是将它作为 xadmin 的插件步骤。

xadmin 插件制作

找到 xadmin 目录下的 plugins 文件夹,此文件下大多为 xadmin 的插件,新建 ueditor.py 文件,代码及说明如下:

# ueditor.py   写法较为固定
import xadmin
from xadmin.views import BaseAdminPlugin, CreateAdminView, ModelFormAdminView, UpdateAdminView
from DjangoUeditor.models import UEditorField
from DjangoUeditor.widgets import UEditorWidget
from django.conf import settings


class 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)

 

然后在 plugins 文件下找到 __init__.py 文件,在代码中加入:

# __init__.py 
PLUGINS = (
    ...
    'ueditor'
)

这样,在 xadmin 启动的时候,ueditor 会得到加载。

在后台页面中查看如下:

 

 

 

tips:如果你的csrf没有注释掉,上传图片时会出现上传失败现象

如果你的django项目是前后端不分离的,csrf中间件必须需要用到,你可以采用下面的方式

解决方案:

找到项目中的 site-packages ,再找到 DjangoUeditor 下的 views.py 文件:

# views.py 
@csrf_exempt   # 查看是否有此行代码,如没有,添加此行代码,表示对这个视图不检验csrf
def get_ueditor_controller(request):
    """获取ueditor的后端URL地址    """
    ...
    return reponseAction[action](request)

完成到这里,Xadmin 的插件就算制作完成。

可能会遇到错误:

render() got an unexpected keyword argument 'renderer'

 

报错93行:boundfield.py in as_widget, line 93
解决方法:注释掉!
如图:

 

 

参考资料:

django-ueditor 下载地址:https://github.com/zhangfisher/DjangoUeditor

ueditor 官网:http://ueditor.baidu.com/website/

Xadmin 官网:http://sshwsfc.github.io/Xadmin/

Xadmin 文档:http://Xadmin.readthedocs.io/en/docs-chinese/make_plugin.html

ueditor 官网:http://ueditor.baidu.com/website/

 

 
  

转载于:https://www.cnblogs.com/dongxixi/p/11239285.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
DjangoUeditor将Ueditor封装为一个Django app,提供文件/图片等上传功能,提供UEditorField、UEditorWidget等封装类,简化Ueditor在Django中的应用。注:Django是Python世界影响最大的Web框架。 本模块帮助在Django应用中集成百度Ueditor HTML编辑器,Django是Python世界最有影响力的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装饰 相关阅读 百度编辑器UEditorDjangoUeditor使用方法
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值