2

我创建了一个基本的 Django 应用程序,其中包含根据 Django Book 的书籍/作者/出版商 - 尝试使用 ModelForm 创建修改现有书籍的方法 - 问题是“作者”字段是 ManyToManyField,当我在 ModelForm 上选择一个选项,它只会擦除现有的选择而不保存新的选择?

模型.py

class Book(models.Model):
    title = models.CharField(max_length=100)
    authors = models.ManyToManyField2(Author)
    publisher = models.ForeignKey(Publisher)
    publication_date = models.DateField()

    def __unicode__(self):
        return self.title

class BookForm(ModelForm):
    class Meta:
        model = Book

    authors = forms.ModelMultipleChoiceField(queryset=Author.objects.all(), required=False)

视图.py

def editBook(request, b=None):
    instance = None
    if b is not None:
        instance = Book.objects.get(title=b)
    if request.method == 'POST':
        form = BookForm(request.POST, instance=instance)
        if form.is_valid():
            form.save()
            return HttpResponseRedirect('/contact/thanks/')
    else:
        form = BookForm(instance=instance)
    return render_to_response('book_form.html', {'form':form})

干杯!

编辑 我刚刚在views.py中发现了几篇鼓励以下内容的文章

authors = form.save(commit=False)
authors.user = request.user
authors.save()
form.save_m2m()

但仍然没有任何运气 - 不可能这么难!

4

2 回答 2

2

解决方案是覆盖 ModelForm 中的保存方法:

def save(self, commit=True):
    authors =[]
    for a in self.cleaned_data['authors']:
         authors.append(Author.objects.get(first_name=t.first_name))

    b = super(BookForm, self).save(commit=commit)

    for a in authors:
        b.authors.add(a)
    b.save()
于 2011-10-17T11:06:13.497 回答
0

因为你覆盖了authors字段。要么不这样做,让 Django 完成它的工作,要么手动处理。

于 2011-10-13T14:24:57.803 回答