參考:http://www.cnblogs.com/qwj-sysu/p/4246605.htmlhtml
作的頁面,一個tr裏有兩個td, 一、三、5等奇數數據要放在第一個td, 二、四、6等偶數數據要放在第二個td, (若是已經沒有數據,td 內容要爲空), 因此要根據取餘數的結果來判斷; 但django的模板沒有取餘操做,只好自定義一個前端
django的模板配置在:setting.py
python
TEMPLATES = [django
{後端
'BACKEND': 'django.template.backends.django.DjangoTemplates',app
1、後端ide
自定義標籤和過濾器必須依賴於一個django app,也就是說,自定義標籤和過濾器是綁定app的。該app應該包含一個templatetags目錄,這個目錄一個和model.py,views.py在同一個層級,記得在該目錄下創建一個__init__.py文件一遍django知道這是一個python包。在該目錄下,你能夠新建一個python模塊文件,文件名不要和其餘app中的衝突就好。例如:函數
promotions
oop
migrations
spa
templatetags
__init__.py
get_mod.py
__init__.py
models.py
views.py
get_mod.py
# -*- coding:utf-8 -*-
from django import template
register = template.Library()
@register.filter
def get_mod(arg1,arg2):
return arg1%int(arg2)
自定義過濾器就是接受一個或者連個參數的python函數。例如{{var | foo:"bar"}},過濾器foo接受變量var和參數bar。
若是前端爲
{{ forloop.counter|get_mod:"2" }}
則爲get_mod(arg1,arg2)
若是前端爲
{{ forloop.counter|get_mod }}
則爲 get_mod(arg1)
2、前端
<table style="background-color:#ffffff;margin-top:30px;width:80%;" class="ke-zeroborder" border="0" cellspacing="50" bordercolor="#000000" cellpadding="0" align="center">
<tbody>
{# 因一行有兩列,因此根據取餘數的結果來判斷是放在第一個td仍是第二個td,若是餘數是1,放在第一個td,若是是2,放在第二個td;若是已經沒有數據,td 內容要爲空#}
{% load get_mod %}
{% for product in product_dict.ring %}
{% if forloop.counter|get_mod:"2" == 1 %}
<tr>
<td style="border-bottom:#ccc 1px solid;text-align:center;border-top:#ccc 1px solid;">
<p>
<a href="` products`.`4 `"><img alt="" src="/static/promotions/` product`.`0 `" /></a>
</p>
<p>
{{ forloop.counter|get_mod:"2" }}` product`.`1 `
<span style="text-align:center;white-space:normal;background-color:#FFFFFF;">(</span><span style="text-align:center;white-space:normal;background-color:#FFFFFF;color:#E53333;">已鎖定</span><span style="text-align:center;white-space:normal;background-color:#FFFFFF;">)</span>
</p>
<p class="MsoNormal">
¥ <span style="line-height:1.5;font-size:12px;">` product`.`3 `</span>
</p>
</td>
{% elif empty %}
<td>
<p></p>
</td>
</tr>
{% else %}
<td style="border-bottom:#ccc 1px solid;text-align:center;border-top:#ccc 1px solid;">
<p>
<a href="` product`.`4 `"><img alt="" src="/static/promotions/` product`.`0 `" /></a>
</p>
<p>
` product`.`1 `(<span style="text-align:center;white-space:normal;background-color:#FFFFFF;color:#E53333;">已鎖定</span>)
</p>
<p class="MsoNormal">
¥ <span style="line-height:1.5;font-size:12px;">` product`.`3 `</span>
</p>
</td>
</tr>
{% endif %}
{% endfor %}
</tbody>
</table>
注意:
{% load %}load的是模塊名,而不是app名
forloop
forloop.counter 表示循環的次數,它從1開始計數
forloop.counter0 表示循環的次數,它從0開始計數
forloop.revcounter表示循環中剩下的items數量,第一次循環時設爲items總數,最後一次設爲1
forloop.revcounter0相似於forloop.revcounter,但它是表示的數量少一個,即最後一次循環時設爲0
forloop.first當第一次循環時值爲True,在特別狀況下頗有用:
{% for object in objects %}
{% if forloop.first %}<li class="first">{% else %}<li>{% endif %}
` object `
</li>
{% endfor %}
forloop.last當最後一次循環時值爲True
{% for link in links %}` link `{% if not forloop.last %} | {% endif %}{% endfor %}
forloop.parentloop在嵌套循環中表示父循環的forloop:
{% for country in countries %}
<table>
{% for city in country.city_list %}
<tr>
<td>Country #` forloop`.`parentloop`.`counter ` </td>
<td>City #` forloop`.`counter `</td>
<td>` city `</td>
</tr>
{% endfor %}
</table>
{% endfor %}