首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >被忽略的django-select2 2小部件的Queryset

被忽略的django-select2 2小部件的Queryset
EN

Stack Overflow用户
提问于 2018-05-29 02:03:38
回答 1查看 2.4K关注 0票数 0

在我的项目中,我大量使用Django- select 2,特别是它的ModelSelect2Widget,因为我的用户经常需要从2,000到6,000项的列表中进行选择。直到现在为止,在我对它的所有使用中,小部件的查询集始终被称为模型的".all()“实例,供用户选择,而且没有问题。

然而,现在,我已经在项目的不同部分实现了这些实现,对于这些实现来说,过滤小部件选项的查询集是必要的。然而,在所有这些情况下,对queryset的任何修改似乎都没有效果,我想知道小部件本身是否有问题。

在主要情况下,数据库中的项被布尔标记为活动/非活动(约65%非活动),我只需要为最终用户选择可用的活动项。

我能够通过shell正确地过滤查询。

在定义形式中,任何筛选(".filter(flag_active=True)",甚至将查询集设置为".none()“)都没有任何效果-下拉/自动完成中的选项没有明显的变化。由于它是一个select2输入,我一次只能查看少量的条目,但是当我输入时,初始检索的总体和筛选的选择都表明过滤器没有被遵循。

代码语言:javascript
复制
MODEL:

class Inventory_product_base(models.Model):
    id = models.UUIDField(primary_key=True,default=uuid.uuid4,null=False)
    upc = models.CharField(max_length=96,null=True,blank=True)
    name = models.CharField('Item name',max_length=96,null=False)
    flag_active = models.BooleanField("Active item",default=True)
    price = models.DecimalField(max_digits=8,decimal_places=3,null=True,blank=True)
    unit_of_measure = models.CharField('UOM',max_length=24, choices=UNITS_OF_MEASURE,default='EACH')
    spec = models.CharField(max_length=36,null=True,blank=True)
    category = models.ForeignKey(Inventory_category,on_delete=models.CASCADE,related_name='cat_products')
    subcategory = models.ForeignKey(Inventory_subcategory,on_delete=models.CASCADE,related_name='subcat_products')
    note = models.CharField(max_length=275,null=True,blank=True)

    def __str__(self):
        return str(self.name)

FORM:

class InventoryCatalogUpdateProductsForm(forms.ModelForm):
    parent_product_base = forms.ModelChoiceField(
        queryset=Inventory_product_base.objects.filter(flag_active=True),
        label=u"",
        widget=ModelSelect2Widget(
            model=Inventory_product_base,
            search_fields=['name__icontains'],
            attrs={'data-placeholder': 'Select product...', 'data-width': '100%'},),)

    class Meta():
        model = Inventory_unit_catalog
        fields = ('parent_product_base',)


class InventoryCatalogUpdateAllProductsForm(forms.ModelForm):
    parent_product_base = forms.ModelChoiceField(
        queryset=Inventory_product_base.objects.all(),
        label=u"",
        widget=ModelSelect2Widget(
            model=Inventory_product_base,
            search_fields=['name__icontains'],
            attrs={'data-placeholder': 'Select product...', 'data-width': '100%'},),)

    class Meta():
        model = Inventory_unit_catalog
        fields = ('parent_product_base',)

InventoryCatalogUpdateProductsFormset = modelformset_factory(model=Inventory_unit_catalog,form=InventoryCatalogUpdateProductsForm,extra=10,can_delete=True)

InventoryCatalogUpdateAllProductsFormset = modelformset_factory(model=Inventory_unit_catalog,form=InventoryCatalogUpdateAllProductsForm,extra=10,can_delete=True)

VIEW:
if product_flag == 'active':
    formset = InventoryCatalogUpdateProductsFormset(queryset=parent_unit_catalog.products.filter(flag_active=True))
else:
    formset = InventoryCatalogUpdateAllProductsFormset(queryset=parent_unit_catalog.products.all())

如前所述,如果我将上述查询集更改为.none() (或小部件或视图中的其他任何内容),则select2字段中呈现的选项没有区别。

我试过不同的,平行的表格和表格集。最初,我尝试了一种更复杂的方法,通过添加以下内容来传递参数,并在单个表单中选择不同的查询集:

代码语言:javascript
复制
def __init__(self, *args, **kwargs):
    self.product_flag = kwargs.pop('product_flag')
    super(InventoryCatalogAddToForm, self).__init__(*args, **kwargs)
    print("__init__ has product_flag: ",self.product_flag)
    if self.product_flag == 'active':
        self.fields['parent_product_base'].queryset = Inventory_product_base.objects.filter(flag_active=True)
        print("Screened for flag_active=True")
    else:
        self.fields['parent_product_base'].queryset = Inventory_product_base.objects.all()
        print("Screened for flag_active=False")

我可以通过调试打印来验证正确的过滤器选择是否正在执行,但没有任何效果。因此,我回到了一种更简单、更直接的独立形式的方法,但仍然什么也没有。

欢迎提出任何建议。我的项目已经进行了几个月,Django-Select2 2是它的基础之一,我不想知道它不能过滤select2输入,我需要找到一个替代品。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2018-05-29 16:54:00

self.fields['parent_product_base'].queryset设置表单字段的查询集(即允许的验证选项)。

使用self.fields['parent_product_base'].widget.queryset设置小部件的选择。

票数 2
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/50575382

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档