在FLask中利用macro实现分页组件

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函数

猜你喜欢

转载自www.cnblogs.com/rlzgqmh/p/11205590.html