我用以下模型创建了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 值,而我只想显示组成数据的字段,而忽略空白值。我该如何解决这个问题,还有更好的方法吗?
答案 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>