아니요, 페이지 매김은 데이터베이스와 매우 긴밀하게 작업해야하기 때문에 토네이도는 DB에 무관합니다.
다음은 내가 사용하는 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 :
tell your tornado app about the module에
{% if pages > 1 %}
<div class="pagination pagination-centered">
<ul>
<li{% if previous %}><a href="{{ get_page_url(previous) }}">«</a>{% else %} class="disabled"><span>«</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) }}">»</a>{% else %} class="disabled"><span>»</span></li>{% end %}
</ul>
</div>
{% end %}
을 잊지 마십시오.
마지막으로, 실제로 그것을 사용 : 도움이
{% for result in results %}
<p>{{ result }}</p>
{% end %}
{% module Paginator(page, page_size, results_count) %}
희망을!
REST와 어떤 관련이 있습니까? –