5

让这些模型:

class Category(models.Model):
    name = models.CharField(max_length=20)

class Word(models.Model):
    name = models.CharField(max_length=200)
    votes = models.IntegerField(default=1)
    categories = models.ManyToManyField(Category, null=True, blank=True)

这种观点:

def main_page(request):
    words = Word.objects.all()
    categories = Category.objects.all()
    return render(request, "main_page.html", {'words': words})

这个模板:

{% for category in categories %}
    {% for word in category.word_set.all %}
    <p>{{ word }}</p>
    {% endfor %}
{% endfor %}

我想分别按票数和发布日期对模板中的单词进行排序。我怎样才能做到这一点?

4

3 回答 3

12

您可以制作自定义模板标签或过滤器,将单词集和排序类型作为参数。

例如(未测试):

custom_tags.py:

from django import template
register = template.Library()

@register.filter
def sort_by(queryset, order):
    return queryset.order_by(order)

模板.html

{% load custom_tags %}
...
{% for word in category.word_set.all|sort_by:'-votes' %}
    <p>{{ word }}</p>
{% endfor %}
...
于 2012-09-02T20:48:24.247 回答
6

您可以在视图中执行此操作

words = Word.objects.all().order_by('votes', 'pub_date')
于 2012-09-02T19:16:20.683 回答
0

你也可以:

  1. 在类别模型中添加特殊方法,
  2. 在 Word 的自定义相关管理器中添加简单的快捷方式,
  3. 在 Word 中将此顺序设为默认值(老实说,我不喜欢这个顺序)
于 2012-09-02T21:16:56.823 回答