博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
循序渐进Python3(十三) --1-- django之form表单
阅读量:6628 次
发布时间:2019-06-25

本文共 1737 字,大约阅读时间需要 5 分钟。

在上一次的代码上做出进一步修改,使之能在页面上显示报错信息。
views.py
 
  1. from django.shortcuts import render, HttpResponse
  2. from django import forms
  3. import json
  4. # Create your views here.
  5. class InputForm(forms.Form):
  6. # 下面使用的变量名必须和html中input标签的name值相同
  7. username = forms.CharField(required=True)
  8. password = forms.CharField(required=True)
  9. def login(request):
  10. if request.method == 'POST':
  11. result = {
    'status':False, 'message':None}
  12. obj = InputForm(request.POST)
  13. ret = obj.is_valid()
  14. # print(ret,obj.data)
  15. if ret:
  16. print(obj.clean())
  17. result['status'] = True
  18. else:
  19. # print(obj.errors)
  20. error_str = obj.errors.as_json()
  21. result['message'] = json.loads(error_str)
  22. return HttpResponse(json.dumps(result))
  23. return render(request, 'login.html')
login.html
 
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>Title</title>
  6. <style>
  7. .error-msg{
  8. color:red;
  9. }
  10. </style>
  11. </head>
  12. <body>
  13. <div>
  14. <div>
  15. <input type="text" name="username" />
  16. </div>
  17. <div>
  18. <input type="password" name="password" />
  19. </div>
  20. <input type="button" value="提交" onclick="DoSubmit();"/>
  21. </div>
  22. <script src="/static/jquery-2.1.4.min.js"></script>
  23. <script>
  24. function DoSubmit() {
  25. var input_dic = {};
  26. $('input').each(function () {
  27. var v = $(this).val();
  28. var n = $(this).attr('name');
  29. input_dic[n] = v;
  30. });
  31. console.log(input_dic);
  32. $.ajax({
  33. url:'/login/',
  34. type:'POST',
  35. data:input_dic,
  36. dataType: 'json',
  37. success: function (rdata) {
  38. if(rdata.status){
  39. location.href = '/index/';
  40. }else{
  41. $.each(rdata.message, function (k,v) {
  42. console.log(k,v[0].message);
  43. var tag = document.createElement('span');
  44. tag.className = 'error-msg';
  45. tag.innerText = v[0].message;
  46. $('input[name="' + k + '"]').after(tag);
  47. })
  48. }
  49. },
  50. error: function () {
  51. }
  52. })
  53. }
  54. </script>
  55. </body>
  56. </html>
效果图:
996586-20170228120001845-1680969019.png
 

转载于:https://www.cnblogs.com/wumingxiaoyao/p/6478280.html

你可能感兴趣的文章
android 避免线程的重复创建(HandlerThread、线程池)
查看>>
手游-放开那三国socket协议分析
查看>>
SQL Lazy Spool Eager Spool
查看>>
type的解释
查看>>
Windows Phone 8 开发环境搭建
查看>>
2017:IDC市场规模将持续增长 增速放缓
查看>>
从自动驾驶到学习机器学习:解读2017科技发展的15大趋势
查看>>
SinoBBD探索"一体化"大数据创新发展
查看>>
互联网金融带来新机遇 数据合规性不容忽视
查看>>
在Linux中永久并安全删除文件和目录的方法
查看>>
全民直播时代 内容监管还得靠技术
查看>>
10款Web开发最佳的Python框架
查看>>
c++ 类的对象与指针
查看>>
Boolean operations between triangle meshes
查看>>
面积并
查看>>
java-JDBC
查看>>
通信术语解释
查看>>
对.NET跨平台的随想
查看>>
ng-view 路由 简单应用
查看>>
Nginx Rewrite规则初探(转)
查看>>