У меня есть две базовые модели: история и категория:
class Category(models.Model):
title = models.CharField(max_length=50)
slug = models.SlugField()
...
class Story(models.Model):
headline = models.CharField(max_length=50)
slug = models.SlugField()
categories = models.ManyToManyField(Category)
...
И мой взгляд на детали истории:
from django.views.generic import date_based, list_detail
from solo.apps.news.models import Story
def story_detail(request, slug, year, month, day):
"""
Displays story detail. If user is superuser, view will display
unpublished story detail for previewing purposes.
"""
stories = None
if request.user.is_superuser:
stories = Story.objects.all()
else:
stories = Story.objects.live()
return date_based.object_detail(
request,
year=year,
month=month,
day=day,
date_field='pub_date',
slug=slug,
queryset=stories,
template_object_name = 'story',
)
На представлении для данного объекта истории - я 'используя общий подробный вид - я хотел бы отобразить список историй, связанных с текущей историей, через категории, примененные к текущей истории.
Вот как я делаю это в настоящее время в деталях историиtemplate:
{% for category in story.category.all %}
<ul id="related_stories">
{% for story in category.story_set.all|slice:"5" %}
<li><a href="{{ story.get_absolute_url }}" title="{{ story.headline }}">{{ story.headline }}</a></li>
{% endfor %}
</ul>
{% endfor %}
Это дает мне то, что мне нужно, за исключением того, что я не хочу отображать связанный заголовок для истории, которую я сейчас просматриваю.
Я полагаю, что это делается с помощьюФильтр «исключить», но я не уверен, относится ли он к модели «Категория» или «История» как метод, или как ее создать.
Любая помощь будет принята с благодарностью!