2013-07-07 25 views
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)に含ま私のメディアデータを取得しなくなります。

誰もがそれを行う方法についてのアイデアを持っている場合...

答えて

13

はこのお試しください:

{% for assoc_media in project.assocprojectmedia_set.all %} 
    {{assoc_media.position}} 
    {# or whatever field #} 
{% endfor %} 
+2

ああ、それは仕事のおかげだと! 'through'関係のrelated_nameを変更することは可能ですか? –

+0

テンプレートのassocprojectmedia_set.all()ではなく、いくつかのフィルタに基づいて1つの行しか取得できませんか?例:project = xx、media = xxの位置を取得したい – Kevin

関連する問題