您可以创建自己的TagField
并将其添加到您的ModelView.
您将不得不覆盖一些字段功能。
我整理了一个使用 select2 版本 4 的演示应用程序,比这个答案更详细一点。
标签字段:
class CustomTagField(Select2TagsField):
widget = CustomTagWidget(multiple=True)
def pre_validate(self, form):
pass
def process_formdata(self, valuelist):
if valuelist:
self.data = []
for tagname in valuelist:
rv = Tag.query.filter_by(name=tagname).first()
if rv:
self.data.append(rv)
else:
self.data.append(Tag(name=tagname))
else:
self.data = []
def iter_choices(self):
self.blank_text = ""
tags = list(set([str(tag.name) for tag in Tag.query.all()]))
model_tags = [tag.name for tag in self.object_data]
self.choices = [[tag, tag] for tag in tags]
# Yield empty object in order to have an empty placeholder
yield (u'__None', self.blank_text, self.data is None)
for value, label in self.choices:
yield (value, label, value in model_tags)
自定义小部件:(类似于Select2TagsWidget
,但未设置data-role
因此form.js
不会使其成为常规 select2 字段)
class CustomTagWidget(widgets.Select):
def __call__(self, field, **kwargs):
kwargs.setdefault('data-tags', '1')
# Or call select2 in tags mode
allow_blank = getattr(field, 'allow_blank', False)
if allow_blank and not self.multiple:
kwargs['data-allow-blank'] = u'1'
return super(CustomTagWidget, self).__call__(field, **kwargs)
在您的管理员中:
form_extra_fields = {
'tags': CustomTagField(
'Tags',
),
}
然后覆盖您的管理模板以在您的字段上以标签模式调用 select2(admin/js/form.js
也将尝试设置该字段的样式):
$('#tags').select2({
tags: true,
});