{% block content %}
{% for blog_dict in blogs|sort(reverse=True,attribute='date') if ((not file_name_filter) or blog_dict.filename==file_name_filter) and ((not category_filter) or blog_dict.category==category_filter) %}
<div id="post{{blog_dict.post_number}}-{{blog_dict.link_name}}">
{{blog_dict.date.strftime("%Y-%m-%d")}}
<a href="/posts/{{blog_dict.filename}}"><h1>{{blog_dict.heading}}</h1></a>
<!-- Place this tag where you want the +1 button to render -->
<div class="g-plusone" data-href="/posts/{{blog_dict.filename}}"></div>
{{blog_dict.post|safe}}
</div>
<br />
<br />
<br />
<img src="/images/page_divider.gif"><br />
{% endfor %}
{% endblock %}
正如你所看到的那样,表达式变得混乱:
{% for blog_dict in blogs|sort(reverse=True,attribute='date') if ((not file_name_filter) or blog_dict.filename==file_name_filter) and ((not category_filter) or blog_dict.category==category_filter) %}
我尝试的另一个选项是在循环中放置两个嵌套的if语句来处理两个过滤器,但嵌套变得很大。
最优雅的是什么?
答案 0 :(得分:4)
正如John Keyes在评论中提到的,我添加了一个过滤器:
def blog_filter(blogs, file_name_filter, category_filter):
if file_name_filter:
blogs = (d for d in blogs if d['filename'] == file_name_filter)
if category_filter:
blogs = (d for d in blogs if d['category'] == category_filter)
return blogs
这被添加到jinja2 environment.filters dict
myconfig = {}
myconfig['webapp2_extras.jinja2'] = {'template_path': ['templates','blog_posts'],
'filters': {'blog_filter': blog_filter}}
app = webapp2.WSGIApplication(_routes,
debug=True,
config = myconfig)
表达式变为:
{% for blog_dict in blogs|blog_filter(file_name_filter,category_filter)|sort(reverse=True,attribute='date') %}
我也可以在其他地方使用此过滤器,例如我的侧边菜单:
{% for month, blog_dicts in blogs|blog_filter(False, category_filter)|groupby('date.month')|sort(reverse=True,attribute='grouper') %}
注意我使用jinja2包装器(来自webapp2_extras import jinja2) 它是我的basehandler中的缓存属性
class BaseHandler(webapp2.RequestHandler):
@webapp2.cached_property
def jinja2(self):
return jinja2.get_jinja2(app=self.app)
def render_template(self, filename, **kwargs):
#call self.response.write(self.jinja2.render_template(..)