0

我有一个简单的 Django 模型结构,其中包含 Products 和 Orders,由一个中间表链接,该表确定给定订单中每个产品的数量:

模型.py:

class Product(models.Model):
    name = models.CharField()

class Order(models.Model):
    id = models.IntegerField()
    products = models.ManyToManyField(Product, through='OrderProduct')

class OrderProduct(models.Model):
    order=models.ForeignKey(Order, on_delete=models.CASCADE)
    product = models.ForeignKey(Product, on_delete=models.CASCADE)
    quantity = models.PositiveSmallIntegerField()

我想在我的 forms.py 文件中设计一个表单,它 1)提取数据库中每个产品的列表;2) 为用户提供调整每个订购产品数量的选项(例如,在 CharField 输入中),以及 3) 创建新的 Order 和 OrderProduct 对象,这些对象存储用户订购的每个产品的数量记录。

但是,我想不出一个好方法来创建一个表单,该表单将自动从数据库中提取所有产品并添加字段来表示给定产品的订购数量。理想情况下,结果看起来像这样,但会自动编码:

表格.py:

class OrderForm(forms.Form):
    product_1_quantity = forms.IntegerField()
    product_2_quantity = forms.IntegerField()
    product_3_quantity = forms.IntegerField()

....等等,对于每个产品。最好的方法是什么?它是否涉及为数据库中找到的每个产品创建一个新字段的“for”循环?

4

3 回答 3

1

我认为 Django Formsets 可能对你有用。您可以根据您决定的数量反复创建相同形式的集合,从而创建您的产品。在这里查看。您可以执行以下示例中的操作。

class ArticleForm(forms.Form):
   title = forms.CharField()

from django.forms import formset_factory
ArticleFormSet = formset_factory(ArticleForm, extra=2)

您还可以使用以下数据预先填充它,

formset = ArticleFormSet(initial=[
      {'title': 'Django is now open source'}
   ])

希望这可以帮助!

于 2017-11-11T01:06:42.633 回答
1

详细说明以下来自 user3140312 的答案——Django 的表单集提供了解决方案!

模型.py:

class Product(models.Model):
    name = models.CharField()

class Order(models.Model):
    id = models.IntegerField()
    products = models.ManyToManyField(Product, through='OrderProduct')

class OrderProduct(models.Model):
    order=models.ForeignKey(Order, on_delete=models.CASCADE)
    product = models.ForeignKey(Product, on_delete=models.CASCADE)
    quantity = models.PositiveSmallIntegerField()

表格.py

class ProductForm(forms.Form):
    product_id = forms.IntegerField(widget=forms.HiddenInput)
    quantity = forms.IntegerField()

视图.py

from .forms import ProductForm
from django.forms import formset_factory
from .models import Product

# Show a form asking for the user's product quantities
def product_form(request):

    # If this form is being processed...
    if request.method == 'POST':

        ProductFormSet = formset_factory(ProductForm)

        # Grab the form from the POST variable
        formset = ProductFormSet(request.POST)

        # If the form is valid...
        if formset.is_valid():

            # Do whatever you want with the results

    # If the form is not being processed, create a new ProductFormSet and render it
    else:

        product_list = []

        for product in Product.objects.all():
            product_list.append({'product_id': product.id, 'quantity': 0})

        ProductFormSet = formset_factory(ProductForm, extra=0)
        formset = ProductFormSet(initial=product_list)
        return render(request, 'template.html', {'formset': formset})

模板.html:

<form action="{% url '' %}" method="post">
    {% csrf_token %}
    {{ formset.as_table }}
    {{ formset.management_form }}
    <input type="submit" value="Submit" />
</form>
于 2017-11-11T01:50:14.030 回答
0

您可以ModelChoiceField在不使用 for 循环的情况下显示所有产品:

class OrderForm(forms.Form):
    product = forms.ModelChoiceField(queryset=Product.objects.all()) # with queryset you can show a checkbox with the query
    quantify = forms.IntegerField()

现在您的视图应该负责保存您的数据。例如,如果您需要一个“添加新”按钮,您可以使用 ajax,否则您可以使用 formset

于 2017-11-11T01:19:04.263 回答