Warning: file_get_contents(/data/phpspider/zhask/data//catemap/2/django/20.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Python 如何在django Detailview中使用多个表单_Python_Django_Django Models_Django Forms_Django Views - Fatal编程技术网

Python 如何在django Detailview中使用多个表单

Python 如何在django Detailview中使用多个表单,python,django,django-models,django-forms,django-views,Python,Django,Django Models,Django Forms,Django Views,我在django博客上有一个评论部分,有两种形式,一种是评论,另一种是回复评论,但是评论形式很好,回复形式不起作用!我试着去做,但还是出错了。。。完整性错误位于/page/9/ 外键约束失败 感谢您的帮助:) 多谢各位 views.py class PostDetailView(DetailView): model = Post template_name = "post_detail.html" context_object_name = 'post' form = CommentForm()

我在django博客上有一个评论部分,有两种形式,一种是评论,另一种是回复评论,但是评论形式很好,回复形式不起作用!我试着去做,但还是出错了。。。完整性错误位于/page/9/ 外键约束失败

感谢您的帮助:) 多谢各位

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

您正在
post
(大纲代码?)中重新定义/丢失
表单
,但这并不能解释
IntegrityError
。您需要详细阅读错误,以找出DB表中哪个字段的无效值导致了该错误。它确实解释了完整性错误:您正在保存
ReplyForm
实例(
form
是您的
ReplyForm
)没有分配
comment
字段,因为您认为它是
CommentForm
。兄弟,对于像我这样的回复,我该怎么做,?在DetailView中是否有任何方法可以同时使用这两种表单@dirkgrotenbro我不明白,你能编辑代码吗?如何真正让它像我想要的那样工作。。。。谢谢兄弟