通用视图允许您编写更短的代码。
比较:
from django.http import HttpResponse, HttpResponseRedirect, Http404
from django.shortcuts import render_to_response, get_object_or_404, redirect
from myapp.models import Context
def edit(request, item_id):
object = get_object_or_404(Context, pk=item_id)
if request.method == 'POST':
form = ContextForm(request.POST, instance=object)
if form.is_valid():
form.save()
return redirect('myapp-context-index')
else:
form = ContextForm(instance=object)
return render_to_response("myapp/context/edit.html", {'object': object, 'form': form})
与:
from django.core import urlresolvers
from django.views.generic.create_update import update_object
from myapp.models import Context
def edit(request, item_id):
return update_object(request,
object_id=item_id,
form_class=ContextForm,
template_name="myapp/context/edit.html",
post_save_redirect=urlresolvers.reverse("myapp-context-index")
)
就像您的正常视图一样,它们只是正常的功能。如果您愿意,可以在 URLconf 中完全配置视图,通过我发现上面的这种用法更清楚一些。
作为奖励,您还可以获得:
- 登录验证检查(通过
login_required=True)
- 来自
django.contrib.messages 的成功状态消息。
- 检查错误的代码更少。
- 当您提供
model 参数而不是form_class 时,默认ModelForm。
template_name 的默认值为“appname/model_form.html”,但这对我来说有点太多了。
这是他们共享的表单类:
class ContextForm(forms.ModelForm):
"""The form for a context"""
class Meta:
model = Context
exclude = ('collection',)
def save(self, commit=True):
"""Overwritten save to force collection_id to a value"""
model = super(ContextForm, self).save(commit=False)
model.collection_id = 1
if commit:
model.save()
return model