从Django模板中删除所有文件

时间:2019-12-06 10:33:34

标签: python django

我用以下模型创建了django模板

Models.py

class MaterialRequest(models.Model):
    owner = models.ForeignKey(Client, on_delete=models.CASCADE, related_name='allotment_sales')

    product1 = models.CharField(max_length=500,default=0,blank=True,null=True)
    product1_quantity = models.IntegerField(default=0,blank=True,null=True)

    product2 = models.CharField(max_length=500,default=0, blank=True,null=True)
    product2_quantity = models.IntegerField(default=0,blank=True,null=True)

    product3 = models.CharField(max_length=500,default=0, blank=True,null=True)
    product3_quantity = models.IntegerField(default=0,blank=True,null=True)

    product4 = models.CharField(max_length=500,default=0, blank=True,null=True)
    product4_quantity = models.IntegerField(default=0,blank=True,null=True)

    product5 = models.CharField(max_length=500,default=0, blank=True,null=True)
    product5_quantity = models.IntegerField(default=0,blank=True,null=True)

    product6 = models.CharField(max_length=500,default=0, blank=True,null=True)
    product6_quantity = models.IntegerField(default=0,blank=True,null=True)

    product7 = models.CharField(max_length=500,default=0, blank=True,null=True)
    product7_quantity = models.IntegerField(default=0,blank=True,null=True)

    product8 = models.CharField(max_length=500,default=0, blank=True,null=True)
    product8_quantity = models.IntegerField(default=0,blank=True,null=True)

并且我尝试使用此视图在模板上显示此数据

def load_salesorder(request):
    so_id = request.GET.get('sales_order')
    s_o = MaterialRequest.objects.filter(pk=so_id)
    print("kits=========",s_o)
    return render(request, 'allotment_so.html', {'sales_order': s_o})

HTML

<table class="table table-bordered">
    <thead>
    <tr>
        <th>Product Short Codes</th>
        <th>Product Quantity</th>
    </tr>
    </thead>

    <tbody>
    <div class="table-container">
        {% for i in sales_order %}
        <tr>
            <td class="align-middle">{{ i.product1 }}</td>
            <td class="align-middle">{{ i.product1_quantity }}</td>
        </tr>
        <tr>
            <td class="align-middle">{{ i.product2 }}</td>
            <td class="align-middle">{{ i.product2_quantity }}</td>
        </tr>
        <tr>
            <td class="align-middle">{{ i.product3 }}</td>
            <td class="align-middle">{{ i.product3_quantity }}</td>
        </tr>
        <tr>
            <td class="align-middle">{{ i.product4 }}</td>
            <td class="align-middle">{{ i.product4_quantity }}</td>
        </tr>
        <tr>
            <td class="align-middle">{{ i.product5 }}</td>
            <td class="align-middle">{{ i.product5_quantity }}</td>
        </tr>
        <tr>
            <td class="align-middle">{{ i.product6 }}</td>
            <td class="align-middle">{{ i.product6_quantity }}</td>
        </tr>
        <tr>
            <td class="align-middle">{{ i.product7 }}</td>
            <td class="align-middle">{{ i.product7_quantity }}</td>
        </tr>
        <tr>
            <td class="align-middle">{{ i.product8 }}</td>
            <td class="align-middle">{{ i.product8_quantity }}</td>
        </tr>

        {% endfor %}

    </tbody>

</table>

但是问题在于它还显示ORM的 None 值,而我只想显示组成数据的字段,而忽略空白值。我该如何解决这个问题,还有更好的方法吗?

2 个答案:

答案 0 :(得分:1)

您可以通过模板中的一些if语句来实现:

{% for i in sales_order %}

    {% if i.product1 and i.product1_quantity %}
        <tr>
            <td class="align-middle">{{ i.product1 }}</td>
            <td class="align-middle">{{ i.product1_quantity }}</td>
        </tr>
    {% endif %}

    <!-- same for other fields -->

{% endfor %}

答案 1 :(得分:1)

use可以对每个字段使用if语句:

<tr>
    <td class="align-middle">{% if i.product1 %}{{ i.product1 }}{% endif %}</td>
    <td class="align-middle">{% if i.product1_quantity %}{{ i.product1_quantity }}{% endif %}</td>
</tr>