背景
借助django-admin,可以快速得到CRUD界面,但若需要创建多选标签字段时,需要对表单进行调整
示例
model.py
- 一个tag(标签类),一个book(书本类)
- book携带tag,这里不借助有性能问题的外键
class tag(models.Model): name = models.CharField(max_length=20, verbose_name='标签') class book(models.Model): name = models.CharField(max_length=50, verbose_name='书名') tags = models.TextField(null=True, verbose_name='标签')
admin.py
将对应的model到admin中注册,才能被django-admin发现并使用,所以主要步骤在此,有以下注意点:
- values_list返回:<QuerySet [('tag1', 'tag1'), ('tag2', 'tag2')]>
- 保证最新标签列表:在表单初始化才执行一次标签查询
- 表单修改显示标签:在表单初始化赋值列表对象
# 标签查询 def get_tag_list(): return tag.objects.values_list("name", "name") # 表单类定义 class bookForm(forms.ModelForm): tags = forms.MultipleChoiceField(label='标签', widget=widgets.CheckboxSelectMultiple) def __init__(self, *args, **kwargs): super(cameraForm, self).__init__(*args, **kwargs) # 保证每次初始化有最新的标签列表 self.fields['tags'].choices = get_tag_list() # 由于会在数据库中存储为列表字符串,需在赋值时转回列表对象,才能在修改表单时识别原值 self.initial['tags'] = eval(self.initial['tags']) class Meta: model = book exclude = [] # book扩展 class bookAdmin(admin.ModelAdmin): search_fields = 'name', 'tags') list_display = ( 'name', 'tags') form = bookForm # 注册到admin中 admin.site.register(book, bookAdmin)
处理结果
写入到数据库格式
数据库中以列表形式存储字符串
django表单样式
以上就是django admin实现动态多选框表单的示例代码的详细内容,更多关于django admin多选框表单的资料请关注其它相关文章!