时间:2021-07-01 10:21:17 帮助过:13人阅读
以前,经常将分页与DB混在一起,比如以下的PHP代码:
all('select * from `xxx` limit $start,$step;'); $total = $db->get('select count(*) as `total` form `xxx`;'); //...pagination...
这样的分页明显是不科学的。
为了满足以上的三个条件,就设计了一个简单的分页类(只做示例,应用到项目需要优化代码和严格的检查)
class ProbbsPage:
def __init__(self, total, per = 10):
self.total = total
self.per = per
self.url = ''
self.page = 1
def set_url(self,url):
self.url = url
return self
def set_page(self,page):
self.page = int(page)
return self
def show(self):
if self.total%self.per == 0:
pages = self.total/self.per
else:
pages = self.total/self.per+1
if self.page < 6:
limit_s = 1
else:
limit_s = self.page
if pages < (limit_s+10):
limit_e = pages
else:
limit_e = limit_s+10
pagination = '%s/%s pages '%(self.page,pages)
for i in range(limit_s,limit_e+1):
if i == self.page:
pagination += '%s'%(i,)
else:
pagination += '%s'%(self.url%i,i)
return pagination
pagination =ProbbsPage(总页数,每页数)
url = 'your_page?page=%s';
page_html = pagination.set_url(url).set_page(page).show()
print page_html
#就可以显示出
#当前页/共几页
#页页链接
set_url可以自动根据url进行提取,前提是使用“?页面参数=第几页”等常用的形成(像我使用专门的不期然形式就不可以了)
set_page同上,可以自动从url中上提取
如果做到以上的两步,就可以直接 ProbbsPage(总页数,每页数).show()就可以了,相对来说比较方便
文章来源:http://pjiaxu.com/python/48.html
http://www.bkjia.com/PHPjc/363817.htmlwww.bkjia.comtruehttp://www.bkjia.com/PHPjc/363817.htmlTechArticle分页,在做WEB开发的时候一定会遇到的,可是webpy却没有内置的分布类,只有自己动手写一个简单的分页类。本文,就以webpy(实际只是py...