1

カーソルを使用してページネーションの実用的な実装を提供できる人はいますか?

ほとんどの例は、次のページにアクセスする方法に関するものです。前のページにアクセスできません。

4

2 に答える 2

2
def get(self):
    echo = self.response.out.write
    limit = 10
    if self.is_logged_in():
        curs = Cursor(urlsafe=self.request.get('curs'))

        query = Postdb.query()

        if self.request.get('type') == 'prev':
            query_reverse = query.order(-Postdb.key)

            posts, cursor, more = query_reverse.fetch_page(limit, start_cursor=curs.reversed())

            echo('<ol>')
            for post in reversed(posts):
                echo('<li><a href="'+post.key.urlsafe()+'">'+post.title+'</a></li>')
            echo('</ol>')

            if more and cursor:
                echo('<a href="?type=prev&curs='+cursor.reversed().urlsafe()+'">prev</a> ')

            echo('<a href="?type=next&curs='+curs.urlsafe()+'">next</a>')
        else:
            query_forward = query.order(Postdb.key)

            posts, cursor, more = query_forward.fetch_page(limit, start_cursor=curs)

            echo('<ol>')
            for post in posts:
                echo('<li><a href="'+post.key.urlsafe()+'">'+post.title+'</a></li>')
            echo('</ol>')

            if self.request.get('curs') != '':
                echo('<a href="?type=prev&curs='+curs.urlsafe()+'">prev</a> ')

            if more and cursor:
                echo('<a href="?type=next&curs='+cursor.urlsafe()+'">next</a>')

        echo('<br><br><a href="/auth/posts/list">start</a>')
于 2013-02-01T01:47:19.983 に答える
1

異なるクエリの数が限られている場合は、以下を参照してください。

https://bitbucket.org/viur/server/src/1b739a5e4ff1c2e3ce8933603a6faf32b364e708/indexes.py?at=master

このクラスはすべてのカーソル操作を処理し、ページへの効率的なランダム アクセスを可能にします (つまり、「次へ」を n 回クリックする代わりに、n ページに直接ジャンプできます)。

于 2013-02-01T12:19:28.550 に答える