Tornado 分页问题求解!

2015-05-11 14:12:52 +08:00
 waynee
最近在学习Tornado,在写分页的时候遇到了瓶颈。
是参照这个问答进行写的:
http://stackoverflow.com/questions/15981257/can-tornado-handle-pagination

路径就是:(r"/",MainHandler)

逻辑是:
class MainHandler(BaseHandler):
def get(self,template_variables = {}):
news_timeline = self.news_model.get_all_news() #获取所有news
current_page = int(self.get_argument('page',0)) # 获取当前URL里的page参数
template_variables["news_timeline"] = news_timeline
template_variables["current_page"] = current_page
self.render("index.html",**template_variables)

HTMl是:
<body>
{% for news in news_timeline %}
<a href = "{{ news["news_link"] }}">{{ news["news_name"] }}</a>
{% end %}
{% module Paginator(current_page,5, len(news_timeline)) %}
</body>

但是底部的分页链接能够显示出来,可是所有结果都显示在了一个页面,并没有分开显示。现在找不到问题在哪里,是我少些了什么代码吗?

各位大神,求教!!!
4799 次点击
所在节点    Tornado
8 条回复
waynee
2015-05-11 14:46:21 +08:00
自己顶,搞了两天的,还是没效果。
tpircsboy
2015-05-11 14:57:28 +08:00
tornado并不能帮你处理分页,分页整个逻辑都需要自己来做。而且stackoverflow上那个答案也说了他的代码只是用来生成分页连接,this doesn't limit those results for you, if just builds the pagination links。
所以你需要把你的news_timeline自己分开。
waynee
2015-05-11 15:00:33 +08:00
@tpircsboy 那要在数据库查询的时候 使用 limit?没做过这方面的,求指教。
zuroyu
2015-05-11 15:01:40 +08:00
news_timeline = self.news_model.get_all_news() #获取所有news
这不是所有结果才叫奇怪呢...
Paginator只是实现了展示内容,并没有实现分页功能

建议从简单开始写一个分页功能,搞清楚分页的原理。包含页数是如何算出来的, 如何获取分页内容, 真假分页的区别等...
tpircsboy
2015-05-11 15:17:53 +08:00
@waynee 嗯,数据库查询时需要skip和limit
waynee
2015-05-11 16:18:51 +08:00
@tpircsboy skip 是干吗的?我只用了 limit 也实现了
coderwang
2015-05-11 16:37:38 +08:00
@waynee 就是从第几条开始 mongodb 查询是skip limit , mysql 一个limit 就可以
phithon
2015-05-12 13:25:23 +08:00
你代码并没有分页,而且tornado里也并没有分页的辅助类、方法,分页自己实现。
可以参考我写的Minos里的分页函数:
https://github.com/phith0n/Minos
主要是你后端得进行limit 限制每次查出来的是从几到几个对象。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/190156

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX