2013-04-12 3 views
2

Рамка Django REST позволяет вам установить разбивку на страницы. Когда мы делаем запрос, он возвращает объект JSON с атрибутом «подкачки», который имеет «следующий» и/или «предыдущий» атрибуты, содержащие URL-адреса других страниц (если они существуют).Может ли торнадо обрабатывать пагинацию?

Предоставляет ли Tornado возможность установить Pagination?

Я искал в Интернете пример tornado pagination, но не смог найти.

Любая помощь приветствуется. Благодарим вас заранее.

+0

Что это связано с ОТДЫХОМ? –

ответ

7

Нет, потому что разбиение на страницы должно работать очень близко к базе данных, а Tornado - агностик.

Вот модуль пользовательского интерфейса, который я использую; вам нужен подсчет ваших общих результатов, а также результаты для страницы (это не ограничивает эти результаты для вас, если только строит ссылки разбивки на страницы):

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 %} 

не забудьте tell your tornado app about the module.

Наконец, на самом деле использовать его:

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

Надежда, что помогает!

Смежные вопросы