【发布时间】:2016-09-28 20:54:20
【问题描述】:
我正在努力将JSONEditor 集成到 Django 管理员中。我的模型中有一个字段使用 Postgres JSON,并且这个库中的树编辑器非常完美。
models.py
>class Executable(models.Model):
""" Simplified model for sake of the question."""
recipe = JSONField(null=True, blank=True)
我已经取得了不错的进展(我认为)将 JSONEditor 库集成到 Django Admin 中适当的创建/编辑屏幕中。数据在加载时显示正确,但由于某种原因,当我在 JSONEditorWidget 中进行编辑时,未保存更改。我确定我需要处理一些 save 覆盖,或者我遗漏了一些明显的东西,但我真的不确定从这里去哪里。
admin.py
>import json
from django import forms, utils
from django.contrib import admin
from .models import Executable
class JSONEditorWidget(forms.Widget):
html_template = """
<div id='%(name)s_editor_holder'></div>
<script type="text/javascript">
var options = {
"mode": "tree",
"search": true
};
var %(name)s_editor = new JSONEditor(container, options);
var json = %(value)s
%(name)s_editor.set(json);
%(name)s_editor.expandAll();
var json = %(name)s_editor.get(json);
</script>
<textarea readonly class="vLargeTextField" cols="40" id="id_%(name)s" name="%(name)s" rows="2" height="20px">%(value)s</textarea>
"""
def __init__(self, attrs=None, formats=None, defaults=None):
self.formats = formats
self.defaults = defaults
super(JSONEditorWidget, self).__init__(attrs)
def render(self, name, value, attrs=None):
if isinstance(value, basestring): # Edit existing instance
value = json.loads(value)
result = self.html_template % {
'name': name,
'value': json.dumps(value)
}
return utils.safestring.mark_safe(result)
class ExecutableForm(forms.ModelForm):
recipe = forms.CharField(widget=JSONEditorWidget()) # Kwargs here?
class Meta:
model = Executable
fields = '__all__'
class Media:
css = {
'all': ('http://www.jsoneditoronline.org/app.min.css',) # TEMP
}
js = (
'http://www.jsoneditoronline.org/app.min.js', # TEMP
)
class ExecutableAdmin(admin.ModelAdmin):
model = Executable
form = ExecutableForm
fields = (('request', 'status'), 'recipe')
admin.site.register(Executable, ExecutableAdmin)
【问题讨论】:
-
@e4c5 该库文档齐全,可在 Github 上找到。是什么让你觉得不是?顺便说一句,我还是一个新手程序员,所以也许我错过了一些东西:)
-
对不起,我误会了,我之前没有使用过这个库,但是在访问该站点时,没有可见的开发人员或 github 链接
-
@e4c5 不用担心,链接隐藏在页脚中,我可以看到您如何得出这个结论。我更新了帖子中的链接,指向 GitHub 存储库,而不是演示站点 (github.com/josdejong/jsoneditor)
标签: django django-admin django-widget django-admin-tools django-jsonfield