Django(Python)前后端交互
-
使用Django中自带的模板
-
前端通过form 表单向后端提交数据
# /template/demo/demo.html {% if result == 1 %} <p> 插入成功 </p> {% else if result==2 %} <p>插入失败</p> {% endif %} <form class="layui-form" method="post" action="{% url \'demo:type_add\' %}" enctype="multipart/form-data"> {% csrf_token %} <input type="text" name="type_name" required autocomplete="off" class="layui-input"> <input type="text" name="type_sort" required autocomplete="off" class="layui-input"> <input type="submit" value="提交"> </form>
-
后端通过渲染函数传递数据给模板文件并渲染
# /demo/url.py app_name = \'[demo]\' urlpatterns = [ url(r\'^type_add/\', views.type_add, name=\'type_add\'), ]
# /demo/views.py def type_add(request): # 类型名称 type_name = request.POST[\'type_name\'] # 类型排序 type_sort = request.POST[\'type_sort\'] # 数据库操作 result = DemoType.objects.create(type_name=type_name,type_sort=type_sort) if result: return render(request, \'demo/demo.html\', {\'result\':1}) else: //return HttpResponse(\'插入失败!\') return render(request, \'demo/demo.html\', {\'result\':2})
-
-
使用Ajax
-
前端通过Ajax向后端发送请求提交数据
-
后端返回响应
-
前端收到响应后通过js对页面上显示的东西进行修改
代码1:
# 前端 function demo(demo_id) { $.ajax({ url: \'url\', type: \'POST\', headers: {"X-CSRFToken":\'{{ csrf_token }}\' }, data: {demo_id: demo_id}, dataType:\'json\', success: function (e) { //通过e获取后端返回的数据并对页面上的显示的东西进行修改 }, }) } # 后端 #路由部分与上面所示的类似 #views.py def demo(request): //如果是get请求的话 demo_id = request.GET.get(\'demo_id\',0) demo_id = request.POST.get(\'demo_id\', 0) user_id = request.session.get(\'user_id\', 0) return_param = {} try: // 数据库操作 demo.objects.update_or_create(users_id=user_id, goods_id=goods_id, status=1) return_param[\'status\'] = 200 return_param[\'msg\'] = \'success\' except Exception as e: return_param[\'status\'] = 500 return_param[\'msg\'] = \'fail\' return HttpResponse(json.dumps(return_param))
代码2:
#前端 function demo(demo_id) { $.ajax({ url: \'url\', type: \'POST\', headers: {"X-CSRFToken":\'{{ csrf_token }}\' }, data: JSON.stringify(data), dataType:\'json\', success: function (e) { //console.log(e) //通过e获取后端返回的数据并对页面上的显示的东西进行修改 }, }) } #后端 # 定义一个统用的响应类,方便规范返回给前端东西的格式 # 公共部分可以新建一个文件放在 和settings.py文件 同一个文件夹内 SUCCESS_CODE, FAIL_CODE, PARMS_CODE = 200, 400, 404 class BaseResponse: def __init__(self, **kwargs): self.status_code = kwargs.get(\'code\',0) self.message = kwargs.get(\'msg\',\'\') self.data = kwargs.get(\'data\',[]) #路由部分与上面所示的类似 # 后端的 views.py部分 def demo(request): //如果是get请求的话 demo_id = request.GET.get(\'demo_id\',0) # POST 请求 params = json.loads(request.body) demo_id = params.get(\'demo_id\',0) user_id = request.session.get(\'user_id\', 0) return_param = {} try: // 数据库操作 demo.objects.update_or_create(users_id=user_id, demo_id=demo_id, status=1) return JsonResponse(BaseResponse(code= SUCCESS_CODE, msg=\'success\',data=[]).__dict__) except Exception as e: return JsonResponse(BaseResponse(code=FAIL_CODE, msg=\'fail\').__dict__)
-
注:如需转载请注明出处:https://www.cnblogs.com/zhuchenglin/p/10763795.html
版权声明:本文为zhuchenglin原创文章,遵循 CC 4.0 BY-SA 版权协议,转载请附上原文出处链接和本声明。