webhelpers.paginateで改ページ時にクエリパラメータを維持する方法
-
19-09-2019 - |
質問
これはリストするとき、私は私のコントローラを持っているものです。
def list(self, page=1, **kw):
q = ""
if kw.has_key('q'):
log.debug("searching %s" % kw)
q = kw['q']
if kw.has_key('all'):
q = ""
products = DBSession.query(model.Product).filter(
or_(model.Product.name.like('%%%s%%' % q),
model.Product.description.like('%%%s%%' % q),
model.Product.model.like('%%%s%%' % q),
model.Product.code.like('%%%s%%' % q))).all()
def get_link(product):
return Markup("""<a href="form?id=%s">%s</a>""" % (product.id, product.id))
product_fields = [
(Markup("""<a href="?s=id">Id</a>"""), get_link),
(u'Name', 'name'),
(u'Model', 'model'),
(u'Code', 'code'),
(u'Description', 'description')]
product_grid = MyDataGrid(fields = product_fields)
currentPage = paginate.Page(products, page, items_per_page=50)
return dict(currentPage=currentPage,
title=u'Products List', item=u'product', items=u'products',
data=currentPage.items,
grid=product_grid,
page=u'Search %s results' % q,
q=q,
hits=len(products))
これはHTMLテンプレートフラグメントである。
<h1>List of ${items}</h1>
<form action="list" method="get">
<input name="q" type="text" value="${value_of('q', default='')}"/>
<input type="submit" value="Search"/> <input type="submit" name="all" value="All"/>
</form>
${hits} ${items} found
<p class="pagelist">${currentPage.pager(format='$link_first ~3~ $link_last')}</p>
<div>
${grid(data)}
</div>
<p><a href="${tg.url('form')}">Add a ${item}</a></p>
の検索が細かい」になります「の/リスト?Q =ケーブル」このようなリンクが得られますが、私はページの区切りページの一部をクリックすると、「1,2 ... 8,9」作品の/リスト?ページ= 2 の '
私は私の以前のクエリパラメータまたはリンクへの任意の他のパラメータを追加するにはどうすればよいですか?
解決
しばらくの間、シェル上で試した後、私は解決策を見つけたと思う。
(paginate.Pageから割り当てられた後)currentPageにで定義されてkwargsから辞書がありますので、私はパラメータを送信するいくつかの実験をしたし、それが働きました。これはどのようにされています。
currentPage = paginate.Page(products, page, items_per_page=50)
currentPage.kwargs['q'] = q
return dict(currentPage=currentPage,
title=u'Products List', item=u'product', items=u'products',
data=currentPage.items,
grid=product_grid,
page=u'Search %s results' % q,
q=q,
hits=len(products))
今私は、リンクのこの種類を取得: '?/リストQ =ケーブル&ページ= 2 を' それが最善の解決策やのベストプラクティスの
他のヒント
次のような構文を使用する必要があります:
currentPage.kwargs['q'] = q
currentPage = paginate.Page(
products,
page,
items_per_page=50,
q = q
)
このスニペットのように、リクエストパラメータを更新することができます。
def paginate(self, items, items_per_page=20):
"""https://bitbucket.org/bbangert/webhelpers/src/acfb17881c1c/webhelpers/paginate.py"""
current_page = self.request.GET.get('page') or 1
def page_url(page):
params = self.request.params.copy()
params['page'] = page
return self.request.current_route_url(_query=params)
return Page(collection=items, page=current_page, items_per_page=items_per_page, url=page_url)
所属していません StackOverflow