我有一个产品列表,连续放3个产品并清除行并添加另外3个,这个工作正常但IE6,我知道在每组3个产品周围添加<div>
将解决这个问题目前的模板文件
{% for product in category.products.all %}
<div class="{% cycle 'clear' '' '' %}">
<a href="{% url shop.views.product category.slug product.slug %}"><img src="{{MEDIA_URL}}{{product.mini_thumbnail}}" alt="{{product.name}}" class="thumbnail"/></a>
<div class="prod-details">
<h3><a href="{% url shop.views.product category.slug product.slug %}">{{product.get_product_name}}</a></h3>
<h4 class="strap">{{product.get_product_detail}}</h4>
<p>{{ product.strap }}</p>
<ul>
<li class="price">£{{product.price}}</li>
<li class="quantity">
<select name="quantity_{{product.id}}">
<option label="1" value="1">1</option>
<option label="2" value="2">2</option>
<option label="3" value="3">3</option>
<option label="4" value="4">4</option>
<option label="5" value="5">5</option>
<option label="6" value="6">6</option>
<option label="7" value="7">7</option>
<option label="8" value="8">8</option>
<option label="9" value="9">9</option>
</select>
</li>
<li><a href="{% url shop.views.product category.slug product.slug %}">Details ></a></li>
<li class="right"><input type="submit" name="add_to_basket_{{product.id}}" value="Add to Basket >"/></li>
</ul>
</div>
</div>
{% endfor %}
答案 0 :(得分:37)
codeape的解决方案只有在您使用最近的Django trunk的SVN签出时才有效。如果您使用的是1.1或更低版本,则不支持该语法。
相反,您可以使用divisibleby
过滤器:
{% if forloop.counter|divisibleby:3 %}<div>{% endif %}
答案 1 :(得分:8)
在循环中使用forloop.counter
和模运算符:
{% for ... %}
{% if forloop.counter|divisibleby:3 %}<div>{% endif %}
...
{% if forloop.counter|divisibleby:3 %}</div>{% endif %}
{% endfor %}
请参阅http://docs.djangoproject.com/en/dev/ref/templates/builtins/#for
修改强>
修正了代码示例。