本人项目环境:python3.6.5, django 2.1
最近在做一个项目,无奈人手少,只能把我当作全栈开发来用,在进行前后台交互时,DJango查询到的分页数据进行Json序列化,使用
from django.core import serializers
进行序列化时发现中文变成了Unicode字符(图中有本人QQ,不要加我,不会统一的),
前端接收到之后也是这个数据。
百度到的方法全部是加一个 ensure_ascii = False,亲测无效,下面亲测有效。
下面给出解决办法:
再导入这个包:
from django.core.serializers.json import json
;;;
@isLogin
def managePageData(request):
"""管理标签界面的数据分页ajax请求"""
data = {'status': 'false'} # 默认状态为假
if request.is_ajax():
numberList = Number.objects.all() # 拿到所有的数据
paginator = Paginator(numberList, 10) # 每页十条数据
pageNumber = request.POST.get('page', 1) # 拿到页码,默认首页
try:
pageData = paginator.page(pageNumber) # 拿到对应页面的数据
except PageNotAnInteger:
pageData = paginator.page(1) # 如果页面非法,给第一页
except EmptyPage:
pageData = paginator.page(paginator.num_pages)
# 如果相应页面为空,则给到最后一页
data['status'] = "true"
pageData = serializers.serialize("json", pageData)
pageData = json.loads(pageData, encoding='utf-8')
print(pageData)
data['pageData'] = pageData # 把页面数据传递过去
return JsonResponse(data=data, charset='utf-8')
就像上面代码中,
pageData = serializers.serialize("json", pageData)
pageData = json.loads(pageData, encoding='utf-8')
print(pageData)
data['pageData'] = pageData # 把页面数据传递过去
序列化之后再使用json.loads方法转化一下,就可以解决了。
解决后如图: