0

私は、すべての人およびすべての家に関連付けられたすべてのデータを、それぞれページ付けされた単一のテンプレートに表示しようとしています。問題は、ページネーションの例の人を使用して特定のデータのエントリを表示するたびに発生します。house と呼ばれる他のページネーションがリセットされます。たとえば、 house の 3 ページ目にいて、 person のページの他のエントリを表示しようとするとします。ハウスのページネーションは 1 にリセットされます。このページネーションの競合を修正するにはどうすればよいですか?

モデル

class Person(models.Model):

    user = models.ForeignKey(User)
    name = models.CharField(max_length=100, blank=True)

    def __unicode__(self):
        return self.name

class House(models.Model):

    user = models.ForeignKey(User)
    name = models.CharField(max_length=100)

ビュー

def Display(request):
        user= User.objects.get(username=request.user)
        comment = Person.objects.get(user=user)

        posts = House.objects.filter(user=user)

        paginator = Paginator(comment, 5)

        try: n = int(request.GET.get("n", '1'))
        except ValueError: page = 1

        try:
            comment = paginator.page(n)
        except (InvalidPage, EmptyPage):
            comment = paginator.page(paginator.num_pages)





        paginator = Paginator(posts, 5)

        try: page = int(request.GET.get("page", '1'))
        except ValueError: page = 1

        try:
            posts = paginator.page(page)
        except (InvalidPage, EmptyPage):
            posts = paginator.page(paginator.num_pages)

        return render(request,'display.html',{'posts':posts,'comment':comment})

HTML

{% for p in posts.object_list %}
{{p.name}}
{% endfor %}


    {% if posts.object_list and posts.paginator.num_pages > 1 %}
    <div class="pagination" style="margin-top: 20px; margin-left: -20px; ">


                &nbsp;Page {{ posts.number }} of {{ posts.paginator.num_pages }}<br>

            {% if posts.has_previous %}
                <a class="Link" href= "{% if formula %}?text={{formula}}&{% else %}?{% endif %}page={{ posts.previous_page_number }}">newer entries &lt;&lt; </a>
            {% endif %}
            {% if posts.has_next %}
                <a class="Link" href="{% if formula %}?text={{formula}}&{% else %}?{% endif %}page={{ posts.next_page_number }}"> &gt;&gt; older entries</a>

            {% endif %}
        </span>
    </div>
    {% endif %}


{% for c in comment.object_list %}
{{c.name}}
{% endfor %}

    {% if comment.object_list and comment.paginator.num_pages > 1 %}


                &nbsp;Page {{ comment.number }} of {{ comment.paginator.num_pages }}
                {% if comment.has_previous %}
                <a class="Link" href= "?n={{ comment.previous_page_number }}">newer entries &lt;&lt; </a>
            {% endif %}<br>
            {% if comment.has_next %}
                <a class="Link" href="?n={{ comment.next_page_number }}"> &gt;&gt; older entries</a>

            {% endif %}
        </span>
    </div>
    {% endif %
4

2 に答える 2

1

まず、変数名とすべてを説明する方法が非常に紛らわしいです。

問題は、ページに 2 つの異なる変数を使用していることです: nfor person(またはcomment) とpagefor house(または posts)。それぞれに、 1 つだけでなく<a href="">両方を設定する必要があります。そう:npage

<a class="Link" href= "{% if formula %}?text={{formula}}&{% else %}?{% endif %}page={{ posts.previous_page_number }}&n={{ comment.number }}">newer entries &lt;&lt; </a>
<a class="Link" href="{% if formula %}?text={{formula}}&{% else %}?{% endif %}page={{ posts.next_page_number }}&n={{ comment.number }}"> &gt;&gt; older entries</a>

<a class="Link" href= "?n={{ comment.previous_page_number }}&page={{ posts.number }}">newer entries &lt;&lt; </a>
<a class="Link" href="?n={{ comment.next_page_number }}&page={{ posts.number }}"> &gt;&gt; older entries</a>
于 2013-05-07T13:51:55.730 に答える