簡體   English   中英

如何在 django Detailview 中使用多個表單

[英]how to work with Multiple forms in django Detailview

我在 django 博客中有一個評論部分,有兩種形式,一種是評論,另一種是回復評論,但評論表格工作正常,回復表格不起作用! 我試圖做,但得到錯誤... IntegrityError at /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

如果您不費力地試圖說服基於類的視圖做它不打算做的事情,而是使用普通的舊的基於函數的視圖,您可能會發現它更容易。

這是一個兩種形式的視圖。 代碼已被重構為我認為更好的模式,以驗證兩個表單並重新顯示頂部是否有任何錯誤,然后您只需執行實際工作來創建和保存底部的對象。

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' )   

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM