多重分页(ajax)不适用于django-el-pagination

Zor*_*gan 25 python django ajax jquery pagination

我有2个查询集:发布和评论.我正在使用django-el-pagination来使用ajax渲染它们.

这是我的观点:

def profile(request, user, extra_context=None):

    profile = Profile.objects.get(user__username=user)

    page_template = 'profile.html'

    if request.is_ajax():
        user_queryset = request.GET.get('user_queryset')
        print('Queryset:', user_queryset)
        if user_queryset == 'user_posts':
            page_template = 'user_posts.html'
        elif user_queryset == 'user_comments':
            page_template = 'user_comments.html'
        else:
            pass

    print('Template:', page_template)

    user_posts = Post.objects.filter(user=profile.user).order_by('-date')
    user_comments = Comment.objects.filter(user=profile.user).order_by('-timestamp')

    context = {'user_posts': user_posts,'user_comments': user_comments, 'page_template': page_template}

    if extra_context is not None:
        context.update(extra_context)

    return render(request, page_template, context)
Run Code Online (Sandbox Code Playgroud)

我有一个ajax调用,找出正在使用的查询集.因此,当点击"更多评论"或"更多帖子"(在模板中)以获得更多分页对象时,我知道它来自哪个查询集.但是,当我使用上面的代码并单击'more'作为ajax分页时,它会附加整个页面,而不是相关的子模板(user_posts.htmluser_comments.html).但if request.is_ajax()代码块工作正常;它会打印正确的模板以供使用,所以这不应该正在发生.

当我将该代码块更改为此时

if request.is_ajax():
    page_template = 'user_posts.html'
Run Code Online (Sandbox Code Playgroud)

ajax的Post作品分页.但是,我想添加ajax分页Comment.为什么我最初的if request.is_ajax()工作没有,我该如何解决?

编辑:

点击时的输出more posts:

Queryset: None
Template: profile.html
Queryset: user_posts
Template: user_posts.html
Run Code Online (Sandbox Code Playgroud)

JS

$('body').on('click', '.endless_more', function() {
    console.log($(this).html()); #works successfully 
    var user_queryset;
    if ($(this).html() === 'more posts') {
        console.log('POSTS'); #works successfully 
        var user_queryset = 'user_posts'
    } else if ($(this).html() === 'more user comments') {
        user_queryset = 'user_comments';
        console.log('COMMENTS'); #works successfully 
    } else {
        console.log('none');
    }
    $.ajax({
        type: 'GET',
        url: window.location.href,
        data: {
            'user_queryset': user_queryset
        }

    })
});
Run Code Online (Sandbox Code Playgroud)

profile.html

<!--posts-->
<div class="user_posts_div">
    <div class="endless_page_template">
        {% include "user_posts.html" %}
    </div>
</div>

<!--comments-->
<div class="user_comments_div">
    <div class="endless_page_template">
        {% include "user_comments.html" %}
    </div>
</div>
Run Code Online (Sandbox Code Playgroud)

user_posts.html(子模板)

{% paginate 5 user_posts %}
    {% for post in user_posts %}
        <div class="user_post">
            <p class="user_post_title_p"><a class="user_post_title" href="{% url 'article' category=post.entered_category id=post.id %}">{{ post.title }}</a></p>
            <p class="user_post_category">/{{ post.entered_category }}</p>
            <p class="user_post_date">{{ post.date|timesince }}</p>
        </div>

    {% endfor %}
{% show_more 'more posts' '...' %}
Run Code Online (Sandbox Code Playgroud)

Nee*_*mar 9

下线的输出是多少?

print('Queryset:', user_queryset)
Run Code Online (Sandbox Code Playgroud)

我认为你在下面有问题

user_queryset = request.GET.get('user_queryset')
Run Code Online (Sandbox Code Playgroud)

这不是返回正确的get参数值,以匹配post和comment部分的条件.