我有一个向用户提供内容的 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 →</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)