jinja2中提供了macro宏定义,功能和函数类似,可以传入参数
本文中利用macro函数实现一个单独的分页组件,具体方式如下:
page.html
{% macro page(data,url)%} {%if data %} <ul class="pagination pagination-sm no-margin pull-right"> <li><a href="{{url_for(url,page=1)}}">首页</a></li> {% if data.has_prev%} <li><a href="{{url_for(url,page=data.prev_num)}}">上一页</a></li> {% else %} <li class="disabled"><a href="#">上一页</a></li> {%endif%} {% for p_num in data.iter_pages()%} {%if p_num==data.page %} <li class="active"><a href="#">{{p_num}}</a></li> {%else%} <li><a href="{{url_for(url,page=p_num)}}">{{p_num}}</a></li> {% endif %} {%endfor%} {% if data.has_next%} <li><a href="{{url_for(url,page=data.next_num)}}">下一页</a></li> {% else %} <li class="disabled"><a href="#">下一页</a></li> {%endif%} <li><a href="{{url_for(url,page=data.pages)}}">尾页</a></li> </ul> {% endif %} {% endmacro %}
可以认为定义了一个函数page(data,url),data为Pagination类型的对象,url为要处理的路径
引用方法如下:
导入所在html
{% import 'page.html' as pg%} #起别名,方便调用
在需要分页的地方插入page函数
{{ pg.page(page_data,'admin.user_list')}} #admin.user_list为你的路径名,这里就是admin应用下的user_list方法
views.py
@admin.route('/user/list/<int:page>') def user_list(page=None): if page==None: page=1 page_data=User.query.paginate(page=page,per_page=10) return render_template('admin/user/user_list.html',page_data=page_data) #page_data为一个Pagination对象
所以使用的流程为:
1.views.py中调用paginate函数生成Pagination对象,传入模板
2.前端模板中调用page.html中的page函数,接收视图函数传来的Pagination对象并将其作为参数传入page函数