时间:2021-05-22
结合mysql数据库查询,实现分页效果
@user.route("/user_list",methods=['POST','GET'])def user_list(): p = g.args.get("p", '') #页数 show_shouye_status = 0 #显示首页状态 if p =='': p=1 else: p=int(p) if p > 1: show_shouye_status = 1 mdb = db_session() limit_start = (int(p)-1)*10#起始 sql ="select * from page_text limit {0},10".format(limit_start) user_list=mdb.getMany(sql) sql="select count(id) as total from page_text" count = mdb.getOne(sql)['total'] #总记录 total = int(math.ceil(count/10.0)) #总页数 dic = get_page(total,p) datas={ 'user_list':user_list, 'p': int(p), 'total': total, 'show_shouye_status': show_shouye_status, 'dic_list': dic } return render_template("user_list.html",datas=datas)其中get_page为封装的方法:
def get_page(total,p): show_page = 5 # 显示的页码数 pageoffset = 2 # 偏移量 start = 1 #分页条开始 end = total #分页条结束 if total > show_page: if p > pageoffset: start = p - pageoffset if total > p + pageoffset: end = p + pageoffset else: end = total else: start = 1 if total > show_page: end = show_page else: end = total if p + pageoffset > total: start = start - (p + pageoffset - end) #用于模版中循环 dic = range(start, end + 1) return dic如果这里需要进行前端模板的拼接的话,可以需要以下代码(bootstrap)
<ul class="pagination"> {% if datas.show_shouye_status==1%} <li class=''><a href='/user/user_list?p=1'>首页</a></li> <li class=''><a href='/user/user_list?p={{datas.p-1}}'>上一页</a></li> {%endif%} {% for dic in datas.dic_list %} {% if dic==datas.p%} <li class="active"><a href="/user/user_list?p={{dic}}" rel="external nofollow" rel="external nofollow" >{{dic}}</a></li> {%else%} <li><a href="/user/user_list?p={{dic}}" rel="external nofollow" rel="external nofollow" >{{dic}}</a></li> {%endif%} {%endfor%} {% if datas.p < datas.total%} <li class=''><a href='/user/user_list?p={{datas.p+1}}'>下一页</a></li> <li class=''><a href='/user/user_list?p={{datas.total}}'>尾页</a></li> {%endif%} 共{{datas.total}}页 </ul>bootstrap样式 http://edu.jb51.net/bootstrap/bootstrap-pagination.html
如果是返回给APP端的话,直接返回data数据就可以了。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
一、Flask简介Flask是一个Python实现的Web开发微框架。官网:http://flask.pocoo.org/二、Demo1、代码结构复制代码代码如
本文实例讲述了Python使用Flask框架获取当前查询参数的方法。分享给大家供大家参考。具体如下:这段代码实现Python的Flask框架下获取当前查询参数,
PHP技巧实例:Smarty+adodb分页示例 利用Smarty+adodb分页示例,下面给出的是分页部份的代码。 分页文件:page.lbi当前页/
zf框架的分页示例复制代码代码如下:
本文实例为大家分享了pythonweb框架实现原生分页的具体代码,供大家参考,具体内容如下原生分页器示例#!/usr/bin/envpython#-*-codi