2

我有一个向用户提供内容的 Flask 应用程序。我正在尝试使用Infinite-Scroll在用户向下滚动时向他们显示自动分页的内容,但似乎无法弄清楚我做错了什么。

该应用程序分页一次,但下次无法按预期工作。它旨在使用使用查询参数分配给按钮的令牌进行分页。

滚动时我没有获得第三页内容,而是收到一条消息,指示没有更多内容。这似乎是因为插件使用了一个无效的令牌,它是通过将 10 加到前一个有效令牌上而得出的。我似乎找不到修改此行为的设置,也不知道为什么会发生这种情况。

我已经包含了一个完整的、最小的示例来演示这个问题。任何帮助将不胜感激。

from flask import Flask, render_template, render_template_string, request, make_response, redirect, session, url_for, abort

application = Flask(__name__)
application.debug=True


@application.route('/posts/', methods=['GET'])
def get_posts():

    token = request.args.get('token', None)

    if token:
        token = int(token)

    if token is None:
        posts = [
            {"name" : "Joe", "id" : 1},
            {"name" : "Sam", "id" : 2},
            {"name" : "Kelly", "id" : 3},
            {"name" : "Bob", "id" : 4},
            {"name" : "Raj", "id" : 5},
            {"name" : "Walter", "id" : 6},
            {"name" : "Jason", "id" : 7},
            {"name" : "Sarah", "id" : 8},
            {"name" : "Steph", "id" : 9},
            {"name" : "Peter", "id" : 10},
            {"name" : "Joe", "id" : 12},
            {"name" : "Sam", "id" : 13},
            {"name" : "Kelly", "id" : 14},
            {"name" : "Bob", "id" : 15},
            {"name" : "Raj", "id" : 16},
            {"name" : "Walter", "id" : 17},
            {"name" : "Jason", "id" : 18},
            {"name" : "Sarah", "id" : 19},
            {"name" : "Steph", "id" : 20},
            {"name" : "Peter", "id" : 21},
            {"name" : "Joe", "id" : 1},
            {"name" : "Sam", "id" : 2},
            {"name" : "Kelly", "id" : 3},
            {"name" : "Bob", "id" : 4},
            {"name" : "Raj", "id" : 5},
            {"name" : "Walter", "id" : 6},
            {"name" : "Jason", "id" : 7},
            {"name" : "Sarah", "id" : 8},
            {"name" : "Steph", "id" : 9},
            {"name" : "Peter", "id" : 10},
            {"name" : "Joe", "id" : 12},
            {"name" : "Sam", "id" : 13},
            {"name" : "Kelly", "id" : 14},
            {"name" : "Bob", "id" : 15},
            {"name" : "Raj", "id" : 16},
            {"name" : "Walter", "id" : 17},
            {"name" : "Jason", "id" : 18},
            {"name" : "Sarah", "id" : 19},
            {"name" : "Steph", "id" : 20},
            {"name" : "Peter", "id" : 21}
        ]

    elif token == 21:
        print "Token is 21"
        posts = [
            {"name" : "Josh", "id" : 42},
            {"name" : "Kevin", "id" : 43},
            {"name" : "Larry", "id" : 44},
            {"name" : "Richard", "id" : 45},
            {"name" : "Carl", "id" : 46},
            {"name" : "Leslie", "id" : 47},
            {"name" : "Jordan", "id" : 48},
            {"name" : "Matt", "id" : 49},
            {"name" : "Steve", "id" : 50},
            {"name" : "Isaac", "id" : 51},
            {"name" : "Joe", "id" : 52},
            {"name" : "Sam", "id" : 53},
            {"name" : "Kelly", "id" : 54},
            {"name" : "Bob", "id" : 55},
            {"name" : "Raj", "id" : 56},
            {"name" : "Walter", "id" : 57},
            {"name" : "Jason", "id" : 58},
            {"name" : "Sarah", "id" : 59},
            {"name" : "Steph", "id" : 60},
            {"name" : "Peter", "id" : 61},
            {"name" : "Josh", "id" : 62},
            {"name" : "Kevin", "id" : 63},
            {"name" : "Larry", "id" : 64},
            {"name" : "Richard", "id" : 65},
            {"name" : "Carl", "id" : 66},
            {"name" : "Leslie", "id" : 67},
            {"name" : "Jordan", "id" : 68},
            {"name" : "Matt", "id" : 69},
            {"name" : "Steve", "id" : 70},
            {"name" : "Isaac", "id" : 71},
            {"name" : "Joe", "id" : 72},
            {"name" : "Sam", "id" : 73},
            {"name" : "Kelly", "id" : 74},
            {"name" : "Bob", "id" : 75},
            {"name" : "Raj", "id" : 76},
            {"name" : "Walter", "id" : 77},
            {"name" : "Jason", "id" : 78},
            {"name" : "Sarah", "id" : 79},
            {"name" : "Steph", "id" : 80},
            {"name" : "Peter", "id" : 81}
        ]

    elif token == 81:
        print "Token is 81"
        posts = [
            {"name" : "Josh", "id" : 42},
            {"name" : "Kevin", "id" : 43},
            {"name" : "Larry", "id" : 44},
            {"name" : "Richard", "id" : 45},
            {"name" : "Carl", "id" : 46},
            {"name" : "Leslie", "id" : 47},
            {"name" : "Jordan", "id" : 48},
            {"name" : "Matt", "id" : 49},
            {"name" : "Steve", "id" : 50},
            {"name" : "Isaac", "id" : 51},
            {"name" : "Joe", "id" : 52},
            {"name" : "Sam", "id" : 53},
            {"name" : "Kelly", "id" : 54},
            {"name" : "Bob", "id" : 55},
            {"name" : "Raj", "id" : 56},
            {"name" : "Walter", "id" : 57},
            {"name" : "Jason", "id" : 58},
            {"name" : "Sarah", "id" : 59},
            {"name" : "Steph", "id" : 60},
            {"name" : "Peter", "id" : 61},
            {"name" : "Josh", "id" : 62},
            {"name" : "Kevin", "id" : 63},
            {"name" : "Larry", "id" : 64},
            {"name" : "Richard", "id" : 65},
            {"name" : "Carl", "id" : 66},
            {"name" : "Leslie", "id" : 67},
            {"name" : "Jordan", "id" : 68},
            {"name" : "Matt", "id" : 69},
            {"name" : "Steve", "id" : 70},
            {"name" : "Isaac", "id" : 71},
            {"name" : "Joe", "id" : 72},
            {"name" : "Sam", "id" : 73},
            {"name" : "Kelly", "id" : 74},
            {"name" : "Bob", "id" : 75},
            {"name" : "Raj", "id" : 76},
            {"name" : "Walter", "id" : 77},
            {"name" : "Jason", "id" : 78},
            {"name" : "Sarah", "id" : 79},
            {"name" : "Steph", "id" : 80},
            {"name" : "Peter", "id" : 101}
        ]

    elif token == 101:
        print "Token is 101"
        posts = [
            {"name" : "Josh", "id" : 42},
            {"name" : "Kevin", "id" : 43},
            {"name" : "Larry", "id" : 44},
            {"name" : "Richard", "id" : 45},
            {"name" : "Carl", "id" : 46},
            {"name" : "Leslie", "id" : 47},
            {"name" : "Jordan", "id" : 48},
            {"name" : "Matt", "id" : 49},
            {"name" : "Steve", "id" : 50},
            {"name" : "Isaac", "id" : 51},
            {"name" : "Joe", "id" : 52},
            {"name" : "Sam", "id" : 53},
            {"name" : "Kelly", "id" : 54},
            {"name" : "Bob", "id" : 55},
            {"name" : "Raj", "id" : 56},
            {"name" : "Walter", "id" : 57},
            {"name" : "Jason", "id" : 58},
            {"name" : "Sarah", "id" : 59},
            {"name" : "Steph", "id" : 60},
            {"name" : "Peter", "id" : 61},
            {"name" : "Josh", "id" : 62},
            {"name" : "Kevin", "id" : 63},
            {"name" : "Larry", "id" : 64},
            {"name" : "Richard", "id" : 65},
            {"name" : "Carl", "id" : 66},
            {"name" : "Leslie", "id" : 67},
            {"name" : "Jordan", "id" : 68},
            {"name" : "Matt", "id" : 69},
            {"name" : "Steve", "id" : 70},
            {"name" : "Isaac", "id" : 71},
            {"name" : "Joe", "id" : 72},
            {"name" : "Sam", "id" : 73},
            {"name" : "Kelly", "id" : 74},
            {"name" : "Bob", "id" : 75},
            {"name" : "Raj", "id" : 76},
            {"name" : "Walter", "id" : 77},
            {"name" : "Jason", "id" : 78},
            {"name" : "Sarah", "id" : 79},
            {"name" : "Steph", "id" : 80},
            {"name" : "Peter", "id" : 131}
        ]

    else:
        #abort(404)
        posts = []

    return render_template_string(posts_template, posts=posts)

posts_template = """

<head>
    {% block head %}
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/1.7.2/jquery.min.js"></script>
    <script src="http://html5shim.googlecode.com/svn/trunk/html5.js"></script>
    <script src="http://api.atmosonline.com/rest/namespace/infinitescroll/jquery.infinitescroll.min.js?uid=da8dd05dea2a4ee78ecd636db084bf47%2FA059402892dfadf9552c&expires=1403203192&signature=UciaR6fu6KdQd4ug9X608FXhqSA%3D"></script>

    {% endblock %}
</head>

{% block content %}
<div class="content">
    {% for post in posts %}

        {% if loop.first %}
        <div class="post">
            first: {{ post.name }}<br>
        </div>
        {% elif loop.last %}
        <div class="post">
            last: {{ post.name }}<br><br>
        </div>
            <a id= "pager" href="/posts/?token={{ posts[loop.index0]['id'] }}">Older &rarr;</a>

        {% else %}
        <div class="post">
            {{ post.name }}<br>
        </div>
        {% endif %}

    {% endfor %}
</div>

{% endblock %}

<script>

    $('#pager').infinitescroll(
    {

        loading: {
            finished: undefined,
            finishedMsg: "<em>Congratulations, you've reached the end of the internet.</em>",
            img: "",
            msg: null,
            msgText: "<em>Loading the next set of posts...</em>",
            selector: null,
            speed: 'slow',
            start: undefined
        },
        state: {
            isDuringAjax: false,
            isInvalidPage: false,
            isDestroyed: false,
            isDone: false, // For when it goes all the way through the archive.
            isPaused: false,
            currPage: 1
        },
        debug: true,
        behavior: undefined,
        binder: $(window), // used to cache the selector for the element that will be scrolling
        nextSelector: "a:first",
        navSelector: "#pager",
        contentSelector: "div.content", // rename to pageFragment
        extraScrollPx: 150,
        itemSelector: "div.content div.post",
        animate: false,
        pathParse: undefined,
        dataType: 'html',
        appendCallback: true,
        bufferPx: 40,
        errorCallback: function () { },
        infid: 0, //Instance ID
        pixelsFromNavToBottom: undefined,
        path: undefined, // Can either be an array of URL parts (e.g. ["/page/", "/"]) or a function that accepts the page number and returns a URL
        prefill: false, // When the document is smaller than the window, load data until the document is larger or links are exhausted
        maxPage:undefined // to manually control maximum page (when maxPage is undefined, maximum page limitation is not work)
    });

    </script>

"""


if __name__ == '__main__':
    application.run(host='0.0.0.0', debug=True)
4

1 回答 1

1

我能够解决这个问题。事实证明,无限滚动插件试图使用一些内置的启发式方法来猜测分页。

我最终不得不为pathParse处理我的 URL 的选项编写一个自定义函数,该选项使用令牌而不是页码。

于 2013-06-21T16:25:20.537 回答