как работать с несколькими формами в django Detailview - PullRequest
0 голосов
/ 07 января 2020

У меня есть раздел комментариев в блоге django, и есть две формы: одна для комментария, другая для ответа на комментарий, но форма комментария работает нормально, а форма ответа не работает! я пытался сделать, но получаю сообщение об ошибке ... Не удалось выполнить ограничение IntegrityError в / page / 9 / FOREIGN KEY ...

благодарю за помощь :) Спасибо.

views.py
class PostDetailView(DetailView):
model = Post
template_name = "post_detail.html"
context_object_name = 'post'
form = CommentForm()

def get_object(self):
    obj = super().get_object()
    if self.request.user.is_authenticated:
        PostView.objects.get_or_create(
            user=self.request.user,
            post=obj
        )
    return obj

def get_context_data(self, **kwargs):
    category_count = get_category_count()
    most_recent = Post.objects.order_by('-timestamp')[:3]
    context = super().get_context_data(**kwargs)
    context['most_recent'] = most_recent
    context['page_request_var'] = "page"
    context['category_count'] = category_count
    context['form'] = self.form
    return context



def post(self, request, *args, **kwargs):
    form = CommentForm(request.POST)

    form = ReplyForm(request.POST)# how to work with this form like above from 

    if form.is_valid():
        post = self.get_object()
        form.instance.user = request.user
        form.instance.post = post
        form.save()
        return redirect(reverse("post-detail", kwargs={
            'pk': post.pk
        }))

  models.py

class Reply(models.Model):
    user = models.ForeignKey(User, on_delete=models.CASCADE)
    timestamp = models.DateTimeField(auto_now_add=True)
    content = models.TextField()
    comment = models.ForeignKey('Comment', related_name='replies',default=False, null=True, 
                                     on_delete=models.CASCADE)

    def __str__(self):
         return self.content

class Comment(models.Model):
    user = models.ForeignKey(User, on_delete=models.CASCADE)
    timestamp = models.DateTimeField(auto_now_add=True)
    content = models.TextField()
    post = models.ForeignKey('Post', related_name='comments', default=False, 
                              on_delete=models.CASCADE)

    def __str__(self):
         return self.content

1 Ответ

0 голосов
/ 07 января 2020

Возможно, вам будет проще, если вы не будете пытаться убедить представление на основе классов сделать то, что не было предназначено, а вместо этого используете простое старое представление на основе функций.

Вот представление в двух формах. Код был преобразован в то, что я считаю лучшим шаблоном, для проверки обеих форм и повторного отображения, если что-то не так в верхней части, а затем вы просто выполняете фактическую работу по созданию и сохранению объектов внизу.

def receive_uncoated( request): #Function based view

    # let's put form instantiation in one place not two, and reverse the usual test. This
    # makes for a much nicer layout with actions not sandwiched by "boilerplate" 
    # note any([ ]) forces invocation of both .is_valid() methods 
    # so errors in second form get shown even in presence of errors in first

    args = [request.POST, ] if request.method == "POST" else []
    batchform = CreateUncWaferBatchForm( *args )
    po_form =  CreateUncWaferPOForm(     *args, prefix='po')
    if request.method != "POST" or any(  
        [ not batchform.is_valid(), not po_form.is_valid() ]):

        return render(request, 'wafers/receive_uncoated.html',   # can get this out of the way at the top
            {'batchform': batchform,  
            'po_form': po_form, 
        })

    #POST, everything is valid, do the work

    # create and save some objects based on the validated forms ... 

    return redirect( 'wafers:ok' )   
...