choices=((1,'male'),(2,'female'),(3,'other')) gender=models.IntegerField(choices=choices)
这样就设置了choice参数,在取值时咱们能够这样取前端
from app01 import models user_obj=models.Userinfo.objects.filter(pk=4).firse() print(user_obj.username) print(user_obj.get_gender_display())
针对choices字段 若是你想要获取数字所对应的中文 你不能直接点字段python
固定句式 数据对象.get_字段名_display() 当没有对应关系的时候 该句式获取到的仍是数字jquery
django号称是MTV框架,其实他仍是MVC框架
MTV:
M:models
T: templates
V: views
MVC:
M:models
V: views
C: contronner(路由匹配)ajax
异步提交
同步异步:描述的任务的提交方式
同步:提交任务以后 原地等待任务的返回结果 期间不干任何事儿
异步:提交任务以后 不肯地等待 直接执行下一行代码 任务的返回经过回调机制django
局部刷新json
一个页面,不是总体刷新,而是页面的某个地方局部刷新后端
Ajax是一门js的技术 基于原生js开发的,可是用原生的js写代码过于繁琐
咱们在学的时候 只学如何用jQuery实现ajax浏览器
AJAX 最大的优势是在不从新加载整个页面的状况下,能够与服务器交换数据并更新部分网页内容。
(这一特色给用户的感觉是在不知不觉中完成请求和响应过程)服务器
展现一个前端页面 页面上有三个输入框 前两个框输入数字 点击按钮朝后端发请求
页面不刷新的状况下 完成数字的加法运算
<input type="text" id="t1">+<input type="text" id="t2">=<input type="text" di="t3"> <p> <button id="b1">计算</button> </p>
$('#b1').on('click',function(){ $ajax({ url:'',//提交数据的地址,没有则朝当前地址提交 type:'post',//请求的方式 data:{'t1':$('#t1').val(),'t2':$('#t2').val()},//发送的数据 success:function(data){//data形参指代的就是异步提交的返回结果,经过DOM操做将内容渲染到标签内容上 $('#t3').val(data) } }) })
django后端准对json格式的数据,不会自动帮你解析,会原封不动的给你放到request.body中,你能够手动处理获取数据
json_bytes=request.body json_str=str(json_bytes,encoding='utf-8') json_dict=json.loads(json_str)
注意点:
1.指定contentType参数
contentType:'application/json',
2.要将你发送的数据确保是json格式的
data:JSON.stringify({'username':'jason','password':'123'})
须要利用内置对象Formdata
该对象既能够传普通的值,也能够传文件
# 获取input获取用户上传文件的文件的内容 // 1.先经过jquery查找到该标签 // 2.将jquery对象转换成原生的js对象 // 3.利用原生js对象的方法 直接获取文件内容 $('#t3')[0].files[0] $('#b1').click(function () { // 1.先生成一个formdata对象 var myFormData = new FormData(); // 2.朝对象中添加普通的键值 myFormData.append('username',$("#t1").val()); myFormData.append('password',$("#t2").val()); // 3.朝对象中添加文件数据 // 1.先经过jquery查找到该标签 // 2.将jquery对象转换成原生的js对象 // 3.利用原生js对象的方法 直接获取文件内容 myFormData.append('myfile',$('#t3')[0].files[0]); $.ajax({ url:'', type:'post', data:myFormData, // 直接丢对象 // ajax传文件 必定要指定两个关键性的参数 contentType:false, // 不用任何编码 由于formdata对象自带编码 django可以识别该对象 processData:false, // 告诉浏览器不要处理个人数据 直接发就行 success:function (data) { alert(data) } }) }) """ ajax传文件须要注意的事项 1.利用formdata对象 可以简单的快速传输数据 (普通键值 + 文件) 2.有几个参数 data:formdata对象 contentType:false processData:false """ contentType先后端传输数据编码格式 form表单 默认的提交数据的编码格式是urlencoded urlencoded username=admin&password=123这种就是符合urlencoded数据格式 django后端针对username=admin&password=123的urlencoded数据格式会自动解析 将结果打包给request.POST 用户只须要从request.POST便可获取对应信息 formdata django后端针对formdata格式类型数据 也会自动解析 可是不会方法request.POST中而是给你放到了request.FILES中 ajax ajax默认的提交数据的编码格式也是urlencoded username=jason&password=123 总结:django后端针对不一样的编码格式数据 会有不一样的处理机制以及不一样的获取该数据的方法 """ 先后端在作数据交互的时候 必定必定要代表你所发的的数据究竟是什么格式 前段后交互 你不能骗人家 你的数据时什么格式 你就应该准确无误告诉别人是什么格式 """
将用户表的数据查询出来返回给前端
给前端的是一个大字典,字典里面的数据是一个小小的字段
from django.core import serializers def ser(request): user_queryset = models.Userinfo.objects.all() # [{},{},{},{}] # user_list = [] # for user_obj in user_queryset: # user_list.append({ # 'username':user_obj.username, # 'password':user_obj.password, # 'gender':user_obj.get_gender_display(), # }) res = serializers.serialize('json',user_queryset) print(res) return render(request,'ser.html',locals())
ajax + sweetalert $("#b55").click(function () { swal({ title: "你肯定要删除吗?", text: "删除可就找不回来了哦!", type: "warning", showCancelButton: true, // 是否显示取消按钮 confirmButtonClass: "btn-danger", // 确认按钮的样式类 confirmButtonText: "删除", // 确认按钮文本 cancelButtonText: "取消", // 取消按钮文本 closeOnConfirm: false, // 点击确认按钮不关闭弹框 showLoaderOnConfirm: true // 显示正在删除的动画效果 }, function () { var deleteId = 2; $.ajax({ url: "/delete_book/", type: "post", data: {"id": deleteId}, success: function (data) { if (data.code === 0) { swal("删除成功!", "你能够准备跑路了!", "success"); } else { swal("删除失败", "你能够再尝试一下!", "error") } } }) }); })