Used JsonResponse in CBV examples.

Thanks Hiroki Kiyohara and Tim Graham for the reviews.
This commit is contained in:
Loic Bistuer 2014-07-29 18:45:16 +07:00 committed by Tim Graham
parent 76f2f58a18
commit 7579080899
2 changed files with 11 additions and 18 deletions

View File

@ -217,9 +217,7 @@ AJAX example
Here is a simple example showing how you might go about implementing a form that Here is a simple example showing how you might go about implementing a form that
works for AJAX requests as well as 'normal' form POSTs:: works for AJAX requests as well as 'normal' form POSTs::
import json from django.http import JsonResponse
from django.http import HttpResponse
from django.views.generic.edit import CreateView from django.views.generic.edit import CreateView
from myapp.models import Author from myapp.models import Author
@ -228,15 +226,10 @@ works for AJAX requests as well as 'normal' form POSTs::
Mixin to add AJAX support to a form. Mixin to add AJAX support to a form.
Must be used with an object-based FormView (e.g. CreateView) Must be used with an object-based FormView (e.g. CreateView)
""" """
def render_to_json_response(self, context, **response_kwargs):
data = json.dumps(context)
response_kwargs['content_type'] = 'application/json'
return HttpResponse(data, **response_kwargs)
def form_invalid(self, form): def form_invalid(self, form):
response = super(AjaxableResponseMixin, self).form_invalid(form) response = super(AjaxableResponseMixin, self).form_invalid(form)
if self.request.is_ajax(): if self.request.is_ajax():
return self.render_to_json_response(form.errors, status=400) return JsonResponse(form.errors, status=400)
else: else:
return response return response
@ -249,7 +242,7 @@ works for AJAX requests as well as 'normal' form POSTs::
data = { data = {
'pk': self.object.pk, 'pk': self.object.pk,
} }
return self.render_to_json_response(data) return JsonResponse(data)
else: else:
return response return response

View File

@ -608,8 +608,7 @@ conversion to JSON once.
For example, a simple JSON mixin might look something like this:: For example, a simple JSON mixin might look something like this::
import json from django.http import JsonResponse
from django.http import HttpResponse
class JSONResponseMixin(object): class JSONResponseMixin(object):
""" """
@ -619,19 +618,20 @@ For example, a simple JSON mixin might look something like this::
""" """
Returns a JSON response, transforming 'context' to make the payload. Returns a JSON response, transforming 'context' to make the payload.
""" """
return HttpResponse( return JsonResponse(
self.convert_context_to_json(context), self.get_data(context),
content_type='application/json',
**response_kwargs **response_kwargs
) )
def convert_context_to_json(self, context): def get_data(self, context):
"Convert the context dictionary into a JSON object" """
Returns an object that will be serialized as JSON by json.dumps().
"""
# Note: This is *EXTREMELY* naive; in reality, you'll need # Note: This is *EXTREMELY* naive; in reality, you'll need
# to do much more complex handling to ensure that arbitrary # to do much more complex handling to ensure that arbitrary
# objects -- such as Django model instances or querysets # objects -- such as Django model instances or querysets
# -- can be serialized as JSON. # -- can be serialized as JSON.
return json.dumps(context) return context
.. note:: .. note::