我已经搜索了几天,试图找到一种简单的方法,使用django内置的验证和表单呈现功能,从JsonField创建动态表单。我还没有找到一个包含django的验证和渲染的解决方案,所以我想为此创建一个模块,但我很难弄清楚这些类是如何工作的。
我尝试了几种不同的方法,例如:
models.py
from django.contrib.postgres.fields import JSONField
from django.db import models
class Forklift(models.Model):
name = models.CharField(max_length=50)
json_fields = JSONField()forms.py
from django import forms
from .models import Forklift
fields_dict = {
'name': forms.CharField(max_length=25),
'number': forms.IntegerField()
}
class ModelForm(forms.ModelForm):
class Meta:
model = Forklift
exclude = ['json_fields']
class DynamicForm(forms.Form):
pass这是我得到的错误:
错误
TypeError: metaclass conflict: the metaclass of a derived class must be a (non-strict) subclass of the metaclasses of all its bases它看起来像forms.Form的子类forms.BaseForm和forms.DeclaritaveFieldsMetaclass,但是我想不出如何子类forms.Form来传入字典中的动态字段。我还尝试了以下几种方法:
views.py
from django import forms
from django.shortcuts import render
from .forms import fields_dict
def dynamic_form(request): #__init_subclass__() takes no keyword arguments
class NewForm(forms.BaseForm, fields=fields_dict): # also tried with fields=fields_dict
pass
form = NewForm(request.POST or None)
return render(request, 'template.html', {'form': form})
def dynamic_form(request): # form will only render once then disappear
content = {}
context = {}
dynamic_form = type('dynamic_form', (DynamicForm,), fields_dict)
form = dynamic_form(content)
context = {
'form': form,
}
return render(request, 'activity/dynamic_form.html', context)
def dynamic_form(request): # module 'django.forms' has no attribute 'DeclaritaveFieldsMetaclass'
class NewForm(forms.BaseForm, metaclass=DeclarativeFieldsMetaclass(MediaDefiningClass), data=fields_dict):
pass
form = NewForm(request.POST or None)
return render(request, 'template.html', {'form': form})我不仅仅是想要一个答案,我真正想知道的是,人们是如何遍历所有这些类的,以找出如何对它们进行子类化。我想我可以通过自己编写所有的逻辑、验证等来弄清楚如何让它工作,但我希望这是一个其他人可以使用的模块。
urls.py
from django.urls import path
from .views import dynamic_form, test
urlpatterns = [
path('form/', dynamic_form),
]编辑
我最初是从内存中输入代码的,但有一些打字错误。我从我的代码库中复制了代码,并包含了urls.py。
发布于 2021-04-14 05:47:33
看一下这个第三方软件包django-entangled,然后将表单重写为
from entangled.forms import EntangledModelForm
class DynamicForm(EntangledModelForm):
name = forms.CharField(max_length=25)
number = forms.IntegerField()
class Meta:
model = Forklift
entangled_fields = {'json_fields': ['name', 'number']}然后,在使用标准Django表单时,像往常一样呈现表单。
https://stackoverflow.com/questions/52647346
复制相似问题