Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/jquery/78.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Jquery 无法使用无限卷轴和烧瓶分页_Jquery_Python_Flask_Infinite Scroll - Fatal编程技术网

Jquery 无法使用无限卷轴和烧瓶分页

Jquery 无法使用无限卷轴和烧瓶分页,jquery,python,flask,infinite-scroll,Jquery,Python,Flask,Infinite Scroll,我有一个为用户提供内容的Flask应用程序。我试图用它在用户向下滚动时向他们显示自动分页的内容,但似乎不知道我做错了什么 该应用程序分页一次,但在下次无法按预期工作。它旨在使用一个令牌进行分页,该令牌通过查询参数分配给按钮 滚动时,我没有看到第三页的内容,而是收到一条消息,表明没有更多的内容。这似乎是因为插件使用了一个无效的令牌,该令牌是从将10添加到之前的有效令牌中派生出来的。我似乎找不到修改这种行为的设置,也不知道为什么会发生这种情况 我已经包括了一个完整的,最小的例子来说明这个问题。任何帮

我有一个为用户提供内容的Flask应用程序。我试图用它在用户向下滚动时向他们显示自动分页的内容,但似乎不知道我做错了什么

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

滚动时,我没有看到第三页的内容,而是收到一条消息,表明没有更多的内容。这似乎是因为插件使用了一个无效的令牌,该令牌是从将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)
从flask导入flask、呈现模板、呈现模板字符串、请求、做出响应、重定向、会话、url、中止
应用=烧瓶(名称)
application.debug=True
@application.route('/posts/',methods=['GET'])
def get_posts():
token=request.args.get('token',无)
如果令牌:
令牌=int(令牌)
如果令牌为无:
职位=[
{“name”:“Joe”,“id”:1},
{“name”:“Sam”,“id”:2},
{“name”:“Kelly”,“id”:3},
{“name”:“Bob”,“id”:4},
{“name”:“Raj”,“id”:5},
{“姓名”:“沃尔特”,“身份证”:6},
{“name”:“Jason”,“id”:7},
{“姓名”:“莎拉”,“身份证”:8},
{“name”:“Steph”,“id”:9},
{“姓名”:“彼得”,“身份证”:10},
{“姓名”:“乔”,“身份证”:12},
{“name”:“Sam”,“id”:13},
{“姓名”:“凯利”,“身份证”:14},
{“name”:“Bob”,“id”:15},
{“name”:“Raj”,“id”:16},
{“姓名”:“沃尔特”,“身份证”:17},
{“姓名”:“杰森”,“身份证”:18},
{“姓名”:“莎拉”,“身份证”:19},
{“name”:“Steph”,“id”:20},
{“姓名”:“彼得”,“身份证”:21},
{“name”:“Joe”,“id”:1},
{“name”:“Sam”,“id”:2},
{“name”:“Kelly”,“id”:3},
{“name”:“Bob”,“id”:4},
{“name”:“Raj”,“id”:5},
{“姓名”:“沃尔特”,“身份证”:6},
{“name”:“Jason”,“id”:7},
{“姓名”:“莎拉”,“身份证”:8},
{“name”:“Steph”,“id”:9},
{“姓名”:“彼得”,“身份证”:10},
{“姓名”:“乔”,“身份证”:12},
{“name”:“Sam”,“id”:13},
{“姓名”:“凯利”,“身份证”:14},
{“name”:“Bob”,“id”:15},
{“name”:“Raj”,“id”:16},
{“姓名”:“沃尔特”,“身份证”:17},
{“姓名”:“杰森”,“身份证”:18},
{“姓名”:“莎拉”,“身份证”:19},
{“name”:“Steph”,“id”:20},
{“姓名”:“彼得”,“身份证”:21}
]
elif令牌==21:
打印“令牌为21”
职位=[
{“name”:“Josh”,“id”:42},
{“姓名”:“凯文”,“身份证”:43},
{“姓名”:“拉里”,“身份证”:44},
{“姓名”:“理查德”,“身份证”:45},
{“姓名”:“卡尔”,“身份证”:46},
{“姓名”:“莱斯利”,“身份证”:47},
{“姓名”:“约旦”,“身份证”:48},
{“name”:“Matt”,“id”:49},
{“姓名”:“史蒂夫”,“身份证”:50},
{“姓名”:“以撒”,“身份证”:51},
{“姓名”:“乔”,“身份证”:52},
{“姓名”:“萨姆”,“身份证”:53},
{“姓名”:“凯利”,“身份证”:54},
{“name”:“Bob”,“id”:55},
{“name”:“Raj”,“id”:56},
{“姓名”:“沃尔特”,“身份证”:57},
{“name”:“Jason”,“id”:58},
{“姓名”:“莎拉”,“身份证”:59},
{“name”:“Steph”,“id”:60},
{“姓名”:“彼得”,“身份证”:61},
{“姓名”:“Josh”,“id”:62},
{“姓名”:“凯文”,“身份证”:63},
{“name”:“Larry”,“id”:64},
{“姓名”:“理查德”,“身份证”:65},
{“姓名”:“卡尔”,“身份证”:66},
{“姓名”:“莱斯利”,“身份证”:67},
{“姓名”:“约旦”,“身份证”:68},
{“name”:“Matt”,“id”:69},
{“姓名”:“史蒂夫”,“身份证”:70},
{“姓名”:“艾萨克”,“身份证”:71},
{“姓名”:“乔”,“身份证”:72},
{“姓名”:“萨姆”,“身份证”:73},
{“姓名”:“凯利”,“身份证”:74},
{“name”:“Bob”,“id”:75},
{“name”:“Raj”,“id”:76},
{“姓名”:“沃尔特”,“身份证”:77},
{“name”:“Jason”,“id”:78},
{“姓名”:“莎拉”,“身份证”:79},
{“name”:“Steph”,“id”:80},
{“姓名”:“彼得”,“身份证”:81}
]
elif令牌==81:
打印“令牌是81”
职位=[
{“name”:“Josh”,“id”:42},
{“姓名”:“凯文”,“身份证”:43},
{“姓名”:“拉里”,“身份证”:44},
{“姓名”:“理查德”,“身份证”:45},
{“姓名”:“卡尔”,“身份证”:46},
{“姓名”:“莱斯利”,“身份证”:47},
{“姓名”:“约旦”,“身份证”:48},
{“name”:“Matt”,“id”:49},
{“姓名”:“史蒂夫”,“身份证”:50},
{“姓名”:“以撒”,“身份证”:51},
{“姓名”:“乔”,“身份证”:52},
{“姓名”:“萨姆”,“身份证”:53},
{“姓名”:“凯利”,“身份证”:54},
{“name”:“Bob”,“id”:55},
{“name”:“Raj”,“id”:56},
{“姓名”:“沃尔特”,“身份证”:57},
{“name”:“Jason”,“id”:58},
{“姓名”:“莎拉”,“身份证”:59},
{“name”:“Steph”,“id”:60},
{“姓名”:“彼得”,“身份证”:61},
{“姓名”:“Josh”,“id”:62},
{“姓名”:“凯文”,“身份证”:63},
{“name”:“Larry”,“id”:64},
{“姓名”:“理查德”,“身份证”:65},
{“姓名”:“卡尔”,“身份证”:66},
{“姓名”:“莱斯利”,“身份证”:67},
{“姓名”:“约旦”,“身份证”:68},
{“姓名”:“马特”,“我”