3

Django REST 框架让你设置分页。当我们发出请求时,它会返回一个 JSON 对象,该对象具有一个“分页”属性,该属性具有“下一个”和/或“上一个”属性,其中包含其他页面的 url(如果它们存在)。

Tornado 是否提供设置分页的选项?

我在网上搜索了龙卷风分页示例,但找不到任何内容。

任何帮助表示赞赏。提前谢谢你。

4

1 回答 1

9

不,因为分页需要与数据库密切配合,而 Tornado 与数据库无关。

这是我使用的 UI 模块;您需要计算总结果以及页面结果(如果只是构建分页链接,这不会限制您的结果):

from __future__ import division
import math
import urlparse
import urllib

import tornado.web

def update_querystring(url, **kwargs):
    base_url = urlparse.urlsplit(url)
    query_args = urlparse.parse_qs(base_url.query)
    query_args.update(kwargs)
    for arg_name, arg_value in kwargs.iteritems():
        if arg_value is None:
            if query_args.has_key(arg_name):
                del query_args[arg_name]

    query_string = urllib.urlencode(query_args, True)     
    return urlparse.urlunsplit((base_url.scheme, base_url.netloc,
        base_url.path, query_string, base_url.fragment))

class Paginator(tornado.web.UIModule):
    """Pagination links display."""

    def render(self, page, page_size, results_count):
        pages = int(math.ceil(results_count / page_size)) if results_count else 0

        def get_page_url(page):
            # don't allow ?page=1
            if page <= 1:
                page = None
            return update_querystring(self.request.uri, page=page)

        next = page + 1 if page < pages else None
        previous = page - 1 if page > 1 else None

        return self.render_string('uimodules/pagination.html', page=page, pages=pages, next=next,
            previous=previous, get_page_url=get_page_url)

这是模块模板(上例中的 uimodules/pagination.html):

{% if pages > 1 %}
<div class="pagination pagination-centered">
  <ul>
  <li{% if previous %}><a href="{{ get_page_url(previous) }}">&laquo;</a>{% else %} class="disabled"><span>&laquo;</span></li>{% end %}  
  {% for page_num in xrange(1, pages + 1) %}{# 1-index range #}
  <li{% if page_num != page %}><a href="{{ get_page_url(page_num) }}">{{ page_num }}</a>{% else %} class="active"><span>{{ page_num }}</span></li>{% end %}
  {% end %}
  <li{% if next %}><a href="{{ get_page_url(next) }}">&raquo;</a>{% else %} class="disabled"><span>&raquo;</span></li>{% end %}  
</ul>
</div>
{% end %}

不要忘记告诉您的龙卷风应用程序有关该模块的信息

最后,要实际使用它:

{% for result in results %}
<p>{{ result }}</p>
{% end %}
{% module Paginator(page, page_size, results_count) %}

希望有帮助!

于 2013-04-14T04:43:09.927 回答