gpt4 book ai didi

jquery - 无法使用 Infinite Scroll 和 Flask 进行分页

转载 作者:太空宇宙 更新时间:2023-11-04 06:13:40 25 4
gpt4 key购买 nike

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

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

我没有在滚动时获得第三页内容,而是收到一条消息,指示没有更多内容。这似乎是因为插件使用了一个无效的 token ,该 token 是通过将 10 添加到先前的有效 token 而派生的。我似乎找不到修改此行为的设置,也不知道为什么会这样。

我提供了一个完整的最小示例来演示此问题。任何帮助将不胜感激。

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)

最佳答案

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

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

关于jquery - 无法使用 Infinite Scroll 和 Flask 进行分页,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/17200637/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com