フォームセットをレンダリングし、postメソッドを介して送信されたときにフォームセットを検証するために使用する次のクラスベースのビューがあります。
フォームセットは完全にレンダリングされます。フォームを送信すると、フォームセットを読み取ってエラーがないか確認できます。このクラスのpostメソッドで->errors = backorder_formset.errors
フォームセットにエラーが見つかった場合は、ビューをレンダリングしたいのですが、今回は、POSTから読み取ったフォームセットインスタンスを使用します。ctx = self.get_context_data()
クラスのpostメソッド内でformを呼び出すと、呼び出しから次のエラーが発生しますsuper(MissingProductsListView, self).get_context_data(*args, **kwargs)
。'MissingProductsListView' object has no attribute 'object_list'
Listviewのスーパークラスがこの呼び出しを実行しているようです。queryset = kwargs.pop('object_list', self.object_list)
私の質問は、なぜこのエラーで実行されているのですか?また、このフォームセットをエラーメッセージとともにレンダリングして、投稿後にテンプレートに表示するにはどうすればよいですか?Django1.9.9を使用しています
class MissingProductsListView(generic.ListView):
template_name = 'dashboard/purchaseorder/missing_products.html'
context_object_name = 'backorders'
model = BackOrder
def post(self, request, *args, **kwargs):
backorder_formset = BackOrderFormset(request.POST)
errors = backorder_formset.errors
if backorder_formset.is_valid():
# <process form cleaned data>
return HttpResponseRedirect('/success/')
else:
ctx = self.get_context_data()
return self.render_to_response(ctx)
def accumulate_identical_products_from_backorders(self, back_order_list):
... some code
return sorted_accumulated_dict.values()
def get_context_data(self, *args, **kwargs):
ctx = super(MissingProductsListView, self).get_context_data(*args, **kwargs)
ctx['title'] = _("Missing Products")
if self.request.POST:
ctx['back_order_formset'] = BackOrderFormset(self.request.POST)
else:
accumulated_backorders_per_product = self.accumulate_identical_products_from_backorders(BackOrder.objects.all())
back_orders = BackOrderFormset(initial=[{'product_id': backorder_dict['product_id'],
'product': backorder_dict['title'],
'quantity': backorder_dict['quantity']} for backorder_dict in
accumulated_backorders_per_product])
ctx['back_order_formset'] = back_orders
return ctx
def get_queryset(self):
.. some code
return backorder_list
ここを見て:
class BaseListView(MultipleObjectMixin, View):
"""
A base view for displaying a list of objects.
"""
def get(self, request, *args, **kwargs):
self.object_list = self.get_queryset()
allow_empty = self.get_allow_empty()
if not allow_empty:
# When pagination is enabled and object_list is a queryset,
# it's better to do a cheap query than to load the unpaginated
# queryset in memory.
if self.get_paginate_by(self.object_list) is not None and hasattr(self.object_list, 'exists'):
is_empty = not self.object_list.exists()
else:
is_empty = len(self.object_list) == 0
if is_empty:
raise Http404(_("Empty list and '%(class_name)s.allow_empty' is False.") % {
'class_name': self.__class__.__name__,
})
context = self.get_context_data()
return self.render_to_response(context)
基本的に-POSTハンドラーでこの部分を見逃しました:
self.object_list = self.get_queryset()
そして正直に言うと、これがdjangoの汎用ListViewに投稿を追加するのに良いアイデアかどうかはよくわかりません。FormViewのように見えますが、ここでは間違っている可能性があります。
この記事はインターネットから収集されたものであり、転載の際にはソースを示してください。
侵害の場合は、連絡してください[email protected]
コメントを追加