任何人都可以使用游标提供分页的工作实现吗?
大多数示例都是关于如何访问下一页的。我无法访问之前的页面。
答案 0 :(得分:2)
def get(self):
echo = self.response.out.write
limit = 10
if self.is_logged_in():
curs = Cursor(urlsafe=self.request.get('curs'))
query = Postdb.query()
if self.request.get('type') == 'prev':
query_reverse = query.order(-Postdb.key)
posts, cursor, more = query_reverse.fetch_page(limit, start_cursor=curs.reversed())
echo('<ol>')
for post in reversed(posts):
echo('<li><a href="'+post.key.urlsafe()+'">'+post.title+'</a></li>')
echo('</ol>')
if more and cursor:
echo('<a href="?type=prev&curs='+cursor.reversed().urlsafe()+'">prev</a> ')
echo('<a href="?type=next&curs='+curs.urlsafe()+'">next</a>')
else:
query_forward = query.order(Postdb.key)
posts, cursor, more = query_forward.fetch_page(limit, start_cursor=curs)
echo('<ol>')
for post in posts:
echo('<li><a href="'+post.key.urlsafe()+'">'+post.title+'</a></li>')
echo('</ol>')
if self.request.get('curs') != '':
echo('<a href="?type=prev&curs='+curs.urlsafe()+'">prev</a> ')
if more and cursor:
echo('<a href="?type=next&curs='+cursor.urlsafe()+'">next</a>')
echo('<br><br><a href="/auth/posts/list">start</a>')
答案 1 :(得分:1)
如果您只有有限数量的不同查询,则可能需要查看
https://bitbucket.org/viur/server/src/1b739a5e4ff1c2e3ce8933603a6faf32b364e708/indexes.py?at=master
此类为您处理所有光标内容,并允许对页面进行有效的随机访问(即,您可以直接跳转到页面n,而不必单击“下一步”n次)。