基于类的通用UpdateView内联 [英] Class Based Generic UpdateView inline

查看:144
本文介绍了基于类的通用UpdateView内联的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

我有以下模型

class Cv(models.Model):
    name = models.CharField(_('name'), max_length=250)
    objective = models.CharField(_('objective'), max_length=250)
    slug = models.SlugField(editable=False)

class Position(models.Model):
    cv = models.ForeignKey(Cv, verbose_name=_('cv'))
    start = models.DateField(_('start'))
    end = models.DateField(_('end'))
    name = models.CharField(_('name'), max_length=250)
    currently_employed = models.BooleanField(_('currently employed'))
    sector = models.IntegerField(_('sector'), choices=SECTOR_CHOICES)
    duties = models.TextField(_('duties'))

和以下表单:

class CvForm(ModelForm):
    class Meta:
        model = Cv

class PositionForm(ModelForm):
    class Meta:
        model = Position
        widgets = {
            'start': DateInput(attrs={'class':'datepicker'}),
            'end': DateInput(attrs={'class':'datepicker'}),
        }

PositionFormSet = inlineformset_factory(Cv, Position, form=PositionForm, extra=1)

我创建了以下通用CreateView,它的工作原理很好:

I have created the following Generic CreateView which works great:

class CreateCvView(CreateView):
    model = Cv
    form_class = CvForm
    template_name = 'recruitment/cv/cv_detail.html'

    def get_success_url(self):
        self.success_url = '/'
        return self.success_url

    def get_context_data(self, **kwargs):
        context = super(CreateCvView, self).get_context_data(**kwargs)
        if self.request.POST:
            context['position_form'] = PositionFormSet(self.request.POST)
        else:
            context['position_form'] = PositionFormSet(instance=self.object)
        return context

    def form_valid(self, form):
        self.object = form.save(commit=False)
        self.object.slug = slugify(self.request.user)
        context = self.get_context_data()
        position_form = context['position_form']
        if position_form.is_valid():
            self.object = form.save()
            position_form.instance = self.object
            position_form.save()
            return HttpResponseRedirect(self.get_success_url())
        else:
            return self.render_to_response(self.get_context_data(form=form))

我想做什么是一个UpdateView,所以我复制了createview并将其传递给slug如下:

What I want to do is an UpdateView and so I copied the createview and passed it the slug as follows:

class EditCvView(UpdateView):
    model = Cv
    form_class = CvForm
    template_name = 'recruitment/cv/cv_detail.html'

    def get_success_url(self):
        self.success_url = '/'
        return self.success_url

    def get_context_data(self, **kwargs):
        context = super(EditCvView, self).get_context_data(**kwargs)
        if self.request.POST:
            context['position_form'] = PositionFormSet(self.request.POST)
        else:
            context['position_form'] = PositionFormSet(instance=self.object)
        return context

    def form_valid(self, form):
        self.object = form.save(commit=False)
        self.object.slug = slugify(self.request.user)
        context = self.get_context_data()
        position_form = context['position_form']
        if position_form.is_valid():
            self.object = form.save()
            position_form.instance = self.object
            position_form.save()
            return HttpResponseRedirect(self.get_success_url())
        else:
            return self.render_to_response(self.get_context_data(form=form))

它加载正常,但是当我发布形式我在get_context_data中的PositionFormSet(self.request.POST)上得到一个'列表索引超出范围'错误。有没有人有这个问题?

It loads fine but when I post the form I get a 'list index out of range' error on PositionFormSet(self.request.POST) in get_context_data. Has anyone else had this problem?

推荐答案

在EditCvView:

in EditCvView:

context ['position_form'] = PositionFormSet(self.request.POST,instance = self.object)

context['position_form'] = PositionFormSet(self.request.POST, instance=self.object)

这篇关于基于类的通用UpdateView内联的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持IT屋!

查看全文
登录 关闭
扫码关注1秒登录
发送“验证码”获取 | 15天全站免登陆