Don*_*Don 2 django ajax jquery post
我正在发送带有结构化后期数据的Ajax请求(带有jQuery):
$.post(
myUrl,
{
items: [{code: 'a', description: 'aaa'},
{code: 'b', description: 'bbb'}]
})
Run Code Online (Sandbox Code Playgroud)
我看到的request.POST是:
<QueryDict: {u'items[0][code]': [u'a'],
u'items[0][description]': [u'aaa'],
u'items[1][description]': [u'bbb'],
u'items[1][code]': [u'b']}>
Run Code Online (Sandbox Code Playgroud)
如何处理获取原件的请求items?
(注意request.POST.get('items')不起作用)
我建议您将对象发布为JSON.在Django中,您可以通过将JSON解析为python对象来重新创建结构.
使用jQuery发布JSON
$.post(
myUrl,
JSON.stringify({
items: [{code: 'a', description: 'aaa'},
{code: 'b', description: 'bbb'}]
})
)
Run Code Online (Sandbox Code Playgroud)
在Django视图中解析JSON
from django.http import HttpResponse
from django.utils import simplejson
def my_view(request):
if request.method == 'POST':
json_data = simplejson.loads(request.raw_post_data)
# json_data contains your objects
print json_data['items']
return HttpResponse("Got data")
Run Code Online (Sandbox Code Playgroud)