Не удается загрузить данные через внешние ключи с Crispy Forms - PullRequest
2 голосов
/ 06 марта 2020

Я отображаю значения категорий и подкатегорий, получаю их оттуда и сохраняю как внешний ключ в сущности News.

models.py

class News(models.Model):    
    name = models.CharField(max_length=50)
    pic = models.ImageField()
    catid = models.ForeignKey(SubCat, on_delete = models.DO_NOTHING)

class Cat(models.Model): 
    name = models.CharField(max_length=50)

class SubCat(models.Model):   
    name = models.CharField(max_length=50)
    catid = models.ForeignKey(Cat, on_delete = models.CASCADE)

add_news. html

  <label class="col-md-1 control-label" for="example-text-input">Text Input</label>
  <div class="col-md-5">
       <input id="newstitle" name="newstitle" type="text" class="form-control" placeholder=".col-md-7">
  </div>

  <select id="newscat" name="newscat" class="select-chosen" data-placeholder="Choose a Category.." style="width: 250px;">
     {% for i in subcat %}
         <option value="{{ i.pk }}">{{ i.catid.name }} | {{ i.name }}</option>
     {% endfor %}
  </select>

image Затем я получил все значения с помощью запросов и сохранил их так:

views.py

@login_required(login_url='mylogin')
def news_add(request):
    subCat = SubCat.objects.all()
     catID = request.POST['newscat']
     if request.method == 'POST':
             newstitle = request.POST['newstitle']                      
             newCatID = SubCat.objects.get(pk=catID)
             pic= request.FILES['picture']
             news = News(name=newstitle, catid=newCatID, pic=pic)
             ...
             news.save()
      else:
          return render(request, 'back/news_add.html', {'subcat' : subCat})

Но , теперь как я могу использовать хрустящие формы для отображения того же списка категорий с подкатегориями и сохранить его в моей модели PK (catid)?

Итак, я могу только отобразить это

add_news. html

<div class="col-md-5">
       {{ form.name|as_crispy_field }}
</div>
<div class="col-md-5">
       {{ form.pic|as_crispy_field }}
</div>
<div class="col-md-5">
       {{ form.catid.name|as_crispy_field }} {{ form.name|as_crispy_field }} # Not possible
</div>

forms.py

class NewsForm(ModelForm):
    class Meta:
        model = News
        fields = ['name', 'pic', 'catid',]       
        labels = {'name': _('Title'),                  
                    'catid': _(''),
                    'pic': _('picture'),
                    }

views.py

@login_required(login_url='mylogin')
def news_add(request):
    subCat = SubCat.objects.all()
    if request.method == 'POST':

        form = NewsForm(request.POST, request.FILES)

        if form.is_valid():

            new = form.save()
            new.save()
            #form.save_m2m()

            return redirect('news_list')

    else:
        form = NewsForm()
        #newCatID = get_object_or_404(SubCat, pk = catID)

    return render(request, 'back/news_add.html', {'form':form, 'subcat' : subCat})

Я описал свою проблему как можно более подробно, потому что я думал об этом в течение нескольких дней

1 Ответ

0 голосов
/ 07 марта 2020

Может быть, имеет смысл просто всегда отображать SubCat вместе с Cat:

class SubCat(models.Model):   
    name = models.CharField(max_length=50)
    catid = models.ForeignKey(Cat, on_delete = models.CASCADE)

    def __str__(self):
        return "{} | {}".format(self.catid.name, self.name)

...