class XadminUEditorWidget(UEditorWidget):
def __init__(self,**kwargs):
self.ueditor_options=kwargs
self.Media.js = None
super(XadminUEditorWidget,self).__init__(kwargs)
self.Media.js = None注释掉,UEditor不正常。不注释,m2m不正常。
解决方案:
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
# 添加到footer
def get_media(self, media):
media = media + self.vendor('xadmin.widget.select.js', 'xadmin.widget.select-transfer.js',
'xadmin.plugin.quick-form.js')
return media
# 在我们生成的页面中放入自己的js文件,添加到header
def block_extrahead(self, context, nodes):
# m2m_transfer和ueditor js冲突解决
js = '<link href="/static/xadmin/vendor/select2/select2.css" type="text/css" media="screen" rel="stylesheet">'
js += '<link href="/static/xadmin/vendor/selectize/selectize.css" type="text/css" media="screen" rel="stylesheet">'
js += '<link href="/static/xadmin/vendor/selectize/selectize.bootstrap3.css" type="text/css" media="screen" rel="stylesheet">'
js += '<link href="/static/xadmin/css/xadmin.widget.select-transfer.css" type="text/css" media="screen" rel="stylesheet">'
js += '<script type="text/javascript" src="/static/xadmin/vendor/selectize/selectize.js"></script>'
js += '<script type="text/javascript" src="/static/xadmin/vendor/select2/select2.js"></script>'
js += '<script type="text/javascript" src="/static/xadmin/vendor/select2/select2_locale_zh-hans.js"></script>'
# js += '<script type="text/javascript" src="/static/xadmin/js/xadmin.widget.select.js"></script>'
# js += '<script type="text/javascript" src="/static/xadmin/js/xadmin.widget.select-transfer.js"></script>'
# js += '<script type="text/javascript" src="/static/xadmin/js/xadmin.plugin.quick-form.js"></script>'
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)
~~~python
get_media将这三个js放在get_media方法中。一定放在footer!加在下面的header中无用。
在block_extrahead中放入对比后差的css和js文件。
运行成功。