6
で多対多の余分なフィールドを介してアクセス:ジャンゴ - 私は、次のモデル構造を持つテンプレート
class Project(models.Model):
title = models.CharField(max_length = 100)
publish = models.BooleanField()
cover = models.ForeignKey(GenericMedia, related_name='+')
media = models.ManyToManyField(GenericMedia, through='AssocProjectMedia')
credits = models.ManyToManyField(AssocTitleName)
class GenericMedia(models.Model):
limit = models.Q(model = 'Image') | models.Q(model = 'Other')
content_type = models.ForeignKey(ContentType, limit_choices_to = limit)
object_id = models.PositiveIntegerField()
content_object = generic.GenericForeignKey('content_type', 'object_id')
def __unicode__(self):
return u"%s" % os.path.basename(self.content_object.url.name)
def instance(self):
return self.content_object.__class__.__name__
class AssocProjectMedia(models.Model):
project = models.ForeignKey(Project)
media = models.ForeignKey(GenericMedia)
position = models.PositiveSmallIntegerField()
grid_size = models.PositiveSmallIntegerField(null = True, blank = True)
class Meta:
ordering = ['position']
私は、次のと私のテンプレートで(AssocProjectMediaに含まれる)の位置データを取得するためにしばらくの間しようとしています。私の見解で
:私のテンプレートで
project = get_object_or_404(Project, slug=project_slug)
return render(request, 'projects/projects_details.html', {"project":project})
:
{% for media in project.media_set.all %}
...
{% endfor %}
しかし、これはうまくいかず、何も表示されません。
代わりにした場合、私は書く:
{% for media in project.media.all %}
...
{% endfor %}
私は1つが通過モデル(AssocProjectMedia)に含ま私のメディアデータを取得しなくなります。
誰もがそれを行う方法についてのアイデアを持っている場合...
ああ、それは仕事のおかげだと! 'through'関係のrelated_nameを変更することは可能ですか? –
テンプレートのassocprojectmedia_set.all()ではなく、いくつかのフィルタに基づいて1つの行しか取得できませんか?例:project = xx、media = xxの位置を取得したい – Kevin