Django带搜索功能的下拉框

2022-09-19 12:38:56

原本只做了一个下拉框,后面随着数据越来越多,选择数据就变得很困难。考虑再下拉框中再增加一个搜索功能。

方法一: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']

效果图:

  • 作者:黑面狐
  • 原文链接:https://blog.csdn.net/qq1124794084/article/details/114884751
    更新时间:2022-09-19 12:38:56