有個需求是15天內的文章要添加一個 new 的圖標提示html
1. 從數據庫獲取前面8條數據
articlelist1 = Article.objects.filter(column = Column.objects.get(name="公告欄")).order_by("-stick").order_by("-id").all()[:8]mysql
2. 須要使用自定義過濾器來現實時間對比,由於mysql保存時間類型是有時區的,因此不能直接比較,把字符串轉成時間類型再進行對比,要注意對比的時候,年月日就要和年月日對比,年月日時分秒就要和年月日時分秒對比
@register.filter
def isNew(dateValue):
newSpan = ''
date1 = (datetime.strptime(dateValue, "%Y.%m.%d").date() + timedelta(days = 15))
nowDate = datetime.now().date()
if date1 >= nowDate:
newSpan = '<img class="new-a" src="static/images/home/new_a.gif" />'
return newSpansql
3. 前臺模版輸出過濾器,要注意html要進行安全過濾,要否則就是一個html字符串,沒法渲染
{% for foo in articlelist1 %}
<li class="cf">
<a href="/news/{{ foo.pk }}/" title="{{ foo.title }}">{{ foo.title }}</a>{{ foo.pub_date|date:'Y.m.d'|isNew|safe }}<span>{{ foo.pub_date| date:'Y.m.d' }}</span>
</li>
{% endfor %}數據庫