Django如何使用下拉菜单过滤表格?

时间:2020-06-11 12:52:41

标签: jquery django ajax django-models django-views

我创建了一个收集所有日常收入的应用。该模型如下:

class Income(models.Model):
        date=models.DateField('', default="GG/MM/YYYY")
        income=models.DecimalField()

我创建了一个简单的模板,其中包含表单和数据表,其中包含所有收集的数据。

<form method="post">
<div class="row">
h5>Income data collection</h5>
<div class="row">
             <div class="form-group col-2 0 mb-0" >
                 {{form.income|as_crispy_field}}
             </div>
             <div class="form-group col-2 0 mb-0" >
                 {{form.date|as_crispy_field}}
             </div>
  </div>
        <table class="table" >           
          <thead>
            <tr>
              <th>Income</th>
              <th>Date</th>
            </tr>
          </thead>
          <tbody>
              {% for inc in income%}
              <tr>
                  <td>{{inc.income}}</td>
                  <td>{{inc.date}}</td>                  
              </tr>
              {% endfor %}
          </tbody>
        </table>

在视图中,我添加了以下过滤器:

income=Income.objects.filters(data__year='2020')

在这一点上,我创建了另一个模型,将参考年份设置如下:

我有以下型号

class Timing(models.Model):
    reference_year=models.DecimalField(max_digits=4, decimal_places=0, default="2020")

此模型的视图具有可让客户注册所有参考年(2020、2021等)的形式。现在,我想将reference_yearincome views.py链接。怎么样?带有一个下拉菜单,其中包含所有填充的reference_year。 因此,例如,如果客户在计时模型中保存的reference_year等于2020,则在下拉列表中客户可以选择它,并且视图动态更新过滤器。

1 个答案:

答案 0 :(得分:0)

在您的模型中。py在这两个模型之间添加一对一的关系。

django文档中提供了以下程序,您可以将其用作参考。

    from django.db import models

class Place(models.Model):
    name = models.CharField(max_length=50)
    address = models.CharField(max_length=80)

    def __str__(self):
        return "%s the place" % self.name

class Restaurant(models.Model):
    place = models.OneToOneField(
        Place,
        on_delete=models.CASCADE,
        primary_key=True,
    )
    serves_hot_dogs = models.BooleanField(default=False)
    serves_pizza = models.BooleanField(default=False)