2016-06-06 5 views
0

Ich habe die folgenden Django viele-zu-viele durch Modell-Setup, aber ich kann nicht herausfinden, wie man durch jede Container iterieren, die Liste der Checkboxen erhalten und ob diese Checkboxen wahr oder falsch sind (CheckboxStatus.status).Wie richtig Schablonen-Tags in dieser bestimmten Viele-zu-Viele-Beziehung in Django verwenden?

Die Modelle sind:

class Container(models.Model): 
    name = models.CharField(max_length=200) 
    checkboxes = models.ManyToManyField('Checkbox', 
             through='CheckboxStatus', 
             related_name='containers') 

class Checkbox(models.Model): 
    name = models.CharField(max_length=60) 
    description = models.CharField(max_length=200) 
    order = models.PositiveSmallIntegerField(default=0) 

class CheckboxStatus(models.Model): 
    container = models.ForeignKey(Container, 
              related_name='checkboxstatus') 
    checkbox = models.ForeignKey(Checkbox, related_name='checkboxstatus') 
    status = models.NullBooleanField() 

Ich habe folgendes bekam, wo Object_List = die CheckboxStatus Modell ...

{% for object in object_list. %} 
    {{ object.container }} 
    {{ object.checkbox }} 
    {{ object.status }} 
{% endfor %} 

... aber dies führt zu allen Kontrollkästchen , und ich muss einige Operationen auf jedem Container durchführen. In pseudocode hätte ich gerne:

Aber vielleicht ist die Beziehung einfach nur falsch. Kann mich jemand in die richtige Richtung drängen?

+0

Welche Ressourcen würden Sie auch empfehlen, um über diese Art von Datenbankstrukturen zu erfahren? Ich kann das Konzept dieser komplexeren Datenbankbeziehungen noch nicht erfassen. –

+0

Soll Ihr Checkbox-Modell ein Kontrollkästchen in einem Formular sein? Wie eine Liste von Optionen für einen Container, die über ein Kontrollkästchen ausgewählt werden können? –

+0

Hallo @RobVezina!Ja, was ich gerne tun würde: mehrere "Seecontainer" haben, ein << container >> Modell, geben Sie jedem eine Liste von Checkboxen (Checkbox) wie im << checkbox >> Modell definiert, und haben Sie eine << status >> für diese << Kontrollkästchen für jedes << container >>. Ich habe wahrscheinlich ein falsches Datenbankbeziehungsmodell, denke ich? Vielen Dank für Ihre Antwort! –

Antwort

1

Wenn ich dieses Recht verstehe, glaube ich nicht, dass Sie die durchgehende Tabelle benötigen. Sie sollten die ManyToManyField definieren und dann ein ModelForm und ein CheckboxSelectMultiple Widget verwenden können, um die Optionen als Kontrollkästchen anzuzeigen.

änderte ich die Modelle:

class Container(models.Model): 
    name = models.CharField(max_length=200) 
    options = models.ManyToManyField('Option') 

# I changed the name of the Checkbox model to Option, for clarity. 
class Option(models.Model): 
    name = models.CharField(max_length=60) 
    description = models.CharField(max_length=200) 
    order = models.PositiveSmallIntegerField(default=0) 

von forms.py:

class ContainerOptionsForm(forms.ModelForm): 
class Meta: 
    model = Container 
    fields = ['options'] 

    widgets = { 
     'options': forms.CheckboxSelectMultiple(), 
    } 

Fügen Sie die Optionen Feld in der Vorlage bilden:

{{ form.options }} 

Wenn Sie mehr Kontrolle benötigen Über die Anzeige der Optionsfelder können Sie über das Optionsfeld des Formulars iterieren:

{% for checkbox in form.options %} 
    <label>{{ checkbox.choice_label }} {{ checkbox.tag }}</label>  
{% endfor %} 

Dies sollte es für einen einzelnen Container auf einer Seite kümmern. Wenn Sie mehrere Container auf derselben Seite verwalten müssen, müssen Sie in ModelFormSet suchen.

+0

Ah, das ist sogar besser als meine unten! Danke Rob, das lehrt mich sehr! –

0

Ich habe es behoben.

Modellcode:

class ContainerBox(models.Model): 
    name = models.CharField(max_length=200) 

class CheckBox(models.Model): 
    name = models.CharField(max_length=60) 
    containerbox = models.ManyToManyField(
     ContainerBox, through="CheckBoxStatus") 

class CheckboxStatus(models.Model): 
    containerbox = models.ForeignKey(ContainerBox, on_delete=models.CASCADE) 
    checkbox = models.ForeignKey(CheckBox, on_delete=models.CASCADE) 
    status = models.NullBooleanField() 

und Template-Code:

{% for containerbox in object_list %} 
    <h2>name: {{containerbox.name}}</h2> 

    {% for checkboxstatus in containerbox.checkboxstatus_set.all %} 
     {{ checkboxstatus.status}} ({{ checkboxstatus.checkbox }})<br/> 

    {% endfor %} 
{% endfor %} 

Das tut, was ich es tun müssen: Behälter durchlaufen, dann über Kontrollkästchen. Ich habe nur Checkboxen und Checkbox-Status ausgetauscht.