原本只做了一个下拉框,后面随着数据越来越多,选择数据就变得很困难。考虑再下拉框中再增加一个搜索功能。
方法一:django-select2-forms
可以参考官方文档设置:
https://pypi.org/project/django-select2-forms/2.0.2/
不过对py3和django3的支持不好,会产生报错,所以我放弃了这个方法。
方法二:使用jquery2 select2
可以参考:https://blog.csdn.net/qq_42469759/article/details/89852141
由于对前端知识掌握不透,我也放弃这个
方法三:使用autocomplete_fields
autocomplete_fields是在django2.0的时候增加。
需要关联的表需要在admin中设置搜索字段
search_fields = ('fields',)
搜索的字段需要设置成外键
autocomplete_fields = ['外键字段']
我要实现的功能是,搜索自己的列表并进行关联,所以我的都是在一张表中进行操作。
代码示例:
models.py
class PatchLib(models.Model):
'''补丁库'''
reboot_choices = (
(0, '需要'),
(1, '不需要'),
)
pathid = models.AutoField(primary_key=True, verbose_name='补丁ID')
vendor_pathid = models.CharField(max_length=500, verbose_name='厂商内部补丁唯一标识')
path_type = models.ForeignKey('PatchLib',db_column='path_type',on_delete=models.CASCADE)
admin.py
@admin.register(PatchLib)
class PatchLibAdmin(ImportExportModelAdmin):
form = PatchLibAdminForm
search_fields = ('vendor_pathid',)
autocomplete_fields = ['path_type']
效果图: