循序漸進PYTHON3(十三) --2-- DJANGO之FORM表單(自動生成HTML標簽和自定制提示信息)


在上一次的代碼上做出進一步修改,使之能在頁面上顯示自定制的報錯信息,並且使用form自動創建標簽的功能。
views.py
  1. from django.shortcuts import render,HttpResponse
  2. from django import forms
  3. import json
  4. import re
  5. from django.core.exceptions importValidationError
  6. # Create your views here.
  7. def mobile_validate(value):
  8. mobile_re = re.compile(r'^(13[0-9]|15[012356789]|17[678]|18[0-9]|14[57])[0-9]{8}$')
  9. ifnot mobile_re.match(value):
  10. raiseValidationError('手機號碼格式錯誤')
  11. classInputForm(forms.Form):
  12. # 下面使用的變量名必須和html中input標簽的name值相同
  13. # forms 的字段類型包括:IntegerField,CharField,URLField,EmailField,DateField等,但是沒有手機號
  14. # required=True表示對輸入做驗證
  15. # error_messages 自定制提示信息
  16. username = forms.CharField(required=True, error_messages={'required':'用戶名不能為空'})
  17. password = forms.CharField(required=True,
  18. min_length=6,
  19. max_length=10,
  20. error_messages={'required':'密碼不能為空','min_length':'至少6位',
  21. 'max_length':'至多10位'}
  22. )
  23. num = forms.IntegerField(error_messages={'required':'不能為空','invalid':'必須是數字'})
  24. # 自定制驗證方法關鍵就是參數validators,和自己的函數關聯起來
  25. phone = forms.CharField(validators=[mobile_validate,],)
  26. def login(request):
  27. if request.POST:
  28. objPost =InputForm(request.POST)
  29. ret = objPost.is_valid()
  30. if ret:
  31. print(objPost.clean())
  32. # else:
  33. # # from django.forms.utils import ErrorDict
  34. # print(type(objPost.errors),objPost.errors.as_json())
  35. return render(request,'login.html',{'data': objPost})
  36. else:
  37. objGet =InputForm()
  38. return render(request,'login.html',{'data': objGet})
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. <form action="/login/" method="POST">
  14. <div>
  15. <div>
  16. {{ data.username }}
  17. {%if data.errors.username %}
  18. <span class="error-msg">{{ data.errors.username.0}}</span>
  19. {% endif %}
  20. </div>
  21. <div>
  22. {{ data.password }}
  23. {%if data.errors.password %}
  24. <span class="error-msg">{{ data.errors.password.0}}</span>
  25. {% endif %}
  26. </div>
  27. <div>
  28. {{ data.num }}
  29. {%if data.errors.num %}
  30. <span class="error-msg">{{ data.errors.num.0}}</span>
  31. {% endif %}
  32. </div>
  33. <div>
  34. {{ data.phone }}
  35. {%if data.errors.phone %}
  36. <span class="error-msg">{{ data.errors.phone.0}}</span>
  37. {% endif %}
  38. </div>
  39. <input type="submit" value="提交"/>
  40. </div>
  41. </form>
  42. </body>
  43. </html>
效果圖:
 上面這個圖的提示應該是django 1.10 版本 新增


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM