choices参数

在表格中些字段只有一些固定的字段名,比如

用户的性别(男 女)

用户的学历(大专,本科,博士,硕士)

用户的工作状态(消极,积极)

客户来源

。。。

# 代码展示

class Userinfo(models.Model):

username = models.CharField(max_length=32)

password = models.IntegerField(default=123)

choices = (

(1,'male'),

(2,'female'),

(3,'others')

)

gender = models.IntegerField(choices=choices)

# 针对choices字段 如果你想要通过输入数字获得所对应的中文 你不能直接点字段

# 固定句式 数据对象.get_字段名_display() 当没有对应关系的时候 该句式获取到的还是数字

# gender存的是数字 如果数字在上面的对应关系中 那么在取值的时候 可以通过

user_obj.gender # 数字

user_obj.get_gender_display() # 取到的就是数字对应的解释

# 如果存的数字不在范围内 拿到的还是数字本身

例题:

record_choices = (('checked', "已签到"),

('vacate', "请假"),

('late', "迟到"),

('noshow', "缺勤"),

('leave_early', "早退"),

)

record = models.CharField("上课纪录", choices=record_choices, default="checked",

score_choices = ((100, 'A+'),

(90, 'A'),

(85, 'B+'),

(80, 'B'),

(70, 'B-'),

(60, 'C+'),

(50, 'C'),

(40, 'C-'),

(0, ' D'),

(-1, 'N/A'),

(-100, 'COPY'),

(-1000, 'FAIL'),

)

score = models.IntegerField("本节成绩", choices=score_choices, default=-1)

MTV与MVC模型

本质: MTV框架,其实它还是MVC框架

MTV:

M:models

T:templates

V:views

MVC:

M:models

V: views

C: contronner(路由匹配)

ajax

异步提交

同步异步:描述的任务的提交方式

同步:提交任务之后 原地等待任务的返回结果 期间不干任何事儿

异步:提交任务之后 不愿地等待 直接执行下一行代码 任务的返回通过回调机制

阻塞非阻塞:程序的运行状态

程序运行的三状态图

局部刷新

一个页面 不是整体刷新 而是页面的某个地方局部刷新

ajax基层与优点

我们所学的ajax是基于jQuery封装好简易版本所以你在写ajax的时候一定要确保导入可jQuery

AJAX 最大的优点是在不重新加载整个页面的情况下,可以与服务器交换数据并更新部分网页内容。

(这一特点给用户的感受是在不知不觉中完成请求和响应过程)

有关ajax优点的小例子

# 需求:

展示一个前端页面 页面上有三个输入框 前两个框输入数字 点击按钮朝后端发请求页面不刷新的情况下 完成数字的加法运算

# 部分代码展示

+ =

计算

$('#b1').on('click',function () {

// 朝后端提交post数据

$.ajax({

// 1.到底朝后端哪个地址发数据

url:'', // 专门用来控制朝后端提交数据的地址 不写默认就是朝当前地址提交

// 2.到底发送什么请求

type:'post', // 专门制定ajax发送的请求方式

// 3.发送的数据到底是什么

data:{'t1':$('#t1').val(),'t2':$('#t2').val()},

// 4.异步提交的任务 需要通过回调函数来处理

success:function (data) { // data形参指代的就是异步提交的返回结果

// 通过DOM操作将内容 渲染到标签内容上

$('#t3').val(data)

}

})

})

ajax传json数据

django后端针对json格式的数据 不会自动帮你解析 会直接原封不动的给你放到request.body中

你可以手动处理 获取数据

json_bytes = request.body

json_str = str(json_bytes,encoding='utf-8')

json_dict = json.loads(json_str)

$('#b1').on('click',function () {

// 朝后端提交post数据

$.ajax({

// 1.到底朝后端哪个地址发数据

url:'', // 专门用来控制朝后端提交数据的地址 不写默认就是朝当前地址提交

// 2.到底发送什么请求

type:'post', // 专门制定ajax发送的请求方式

// 告诉后端你当前的数据格式 到底是什么类型

contentType:'application/json',

// 3.发送的数据到底是什么

{#data:{'t1':$('#t1').val(),'t2':$('#t2').val()},#}

data:JSON.stringify({'username':'jason','password':'123'}),

// 4.异步提交的任务 需要通过回调函数来处理

success:function (data) { // data形参指代的就是异步提交的返回结果

// 通过DOM操作将内容 渲染到标签内容上

{#$('#t3').val(data)#}

alert(data)

}

})

})

# 注意点

1.指定contentType参数

contentType:'application/json',

2.要将你发送的数据 确保是json格式的

data:JSON.stringify({'username':'jason','password':'123'})

ajax传文件

需要利用内置对象 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 -- 前后端传输数据编码格式

编码格式种类

1.urlencoded

2.formdata

3.application/json

form表单

form表单默认的编码格式是urlencoded

urlencoded编码格式的数据特点

username=jason&password=123&age=18

# django后端针对符合urlencoded数据格式 会自动解析 并给你封装到request.POST中

# 你可以通过制定enctype参数来修改form表单提交数据的编码格式

# form表单传输文件的时候 编码格式就必须有默认的改为formdata

"""

即可以传普通的键值对也可以上传文件

django后端针对只要是符合urlencoded格式的数据都会自动解析放到request.POST

针对文件数据 会解析并放到request.FILES

"""

ajax 默认的数据编码格式也是urlencoded

也就意味着ajax发送post请求django后端默认也是通过request.POST获取数据

前后端在做数据交互的时候 一定一定要表明你所发的的数据到底是什么格式

前段后交互 你不能骗人家

你的数据时什么格式 你就应该准确无误告诉别人是什么格式

序列化组件

1.将用户表的数据 查询出来 返回给前端

给前端的是一个大字典 字典里面的数据的一个个的字段

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")

}

}

})

});

})

参考博客:https://www.cnblogs.com/Dominic-Ji/p/9234099.html

参考链接:https://lipis.github.io/bootstrap-sweetalert/

原文:https://www.cnblogs.com/asyouwish/p/11762712.html

ajax 传数据视频,Django知识整理四(choices参数,MTV与MVC模型,ajax介绍,ajax传json文件,ajax传文件,contentType前后端传输数据编码格式)...相关推荐

  1. Web框架之Django_07 进阶操作(MTV与MVC、多对多表三种创建方式、前后端传输数据编码格式contentType、ajax、自定义分页器)

    阅读目录 一.MVC与MTV 二.多对多表的创建 三.ajax,前后端传输编码格式contentType 四.批量插入数据与自定义分页器 摘要 MTV与MVC 多对多表三种创建方式 ajax ,前后端 ...

  2. Python Day 67 Dango框架图解(总结)、Wsgiref和uwsgi、前后端传输数据的编码格式、From表单和Ajax方式在前端往后端发送文件、补充一下页面清缓存...

    ##Django框架图解 ##前后端传输数据的编码格式 #前后端传输数据的编码格式1.urlencoded 2.formdata 3.application/json ##From表单和Ajax方式在 ...

  3. Django 数据库查询优化,choices参数(数据库字段设计常见),MVC和MTV模型,多对多三种创建方式...

    数据库查询优化 orm语句的特点:惰性查询 如果仅仅只是书写了orm语句,在后面没有用到该语句所查询出来的参数,那么orm会自动识别,并不执行 举例: res = models.Book.object ...

  4. app用html传数据,通过html调用App并传送参数倒App中

    突然有一天玩360手机助手下载东西,但是点击安装直接就跳转到App中,卧槽,这比较新奇,以前真没觉得有这么一回事,才疏学浅呐. 一.通过html页面打开Android本地的app 简单的html页面 ...

  5. SpringBoot+El-upload实现上传文件到通用上传接口并返回文件全路径(若依前后端分离版源码分析)

    场景 SpringBoot+ElementUI实现通用文件下载请求(全流程图文详细教程): https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/deta ...

  6. MTV和MVC模型和创建Django项目

    MVC与MTV模型 MVC模型 MVC,是软件工程中的一种软件架构模式,把软件系统分为三个基本部分:模型(Model).视图(View)和控制器(Controller),他们之间以一种插件式的.松耦合 ...

  7. [PHP]利用XAMPP搭建本地服务器, 然后利用iOS客户端上传数据到本地服务器中(四. iOS端代码实现)...

    一.安装XAMPP   http://www.cnblogs.com/lidongxu/p/5256330.html 二. 配置MySql  http://www.cnblogs.com/lidong ...

  8. Django学习记录之——choices参数

    choices参数 choices参数:针对表中某个可能列举完全的字段,采用choices参数例如:性别可以列举完全为男女,其他- choice参数使用sex_choices = ((1, '男'), ...

  9. 视频怎么变成gif?快速巧妙生成动图的方法介绍

    视频怎么变成gif?很多人看到gif因为它是动图,可能会觉得它是视频格式的一种.其实不然,gif它是一种图像互换格式,它采用的是一种压缩文档的样式,能够有效地减少图片传输的时间.那么我们应该如何制作g ...

  10. 【四二学堂】jquery方式ajax获取数据并渲染页面

    var newsData = ''; var mydata = {"pageNum":obj.curr,"pageSize":"5"}; / ...

最新文章

  1. 教你两种黑掉“人工智能”的方法
  2. matlab计算电路环流,双反星形整流电路并联运行环流分析
  3. 第3章 衡量线性回归的指标:MSE,RMSE,MAE
  4. Win10+libtorch1.1+opencv 笔记
  5. python-3.8.0 新特性之赋值表达式
  6. Android 中.aar文件生成方法与用法
  7. 【计算机网络】FDM和TDM的传输总时间计算
  8. php清空dns缓存文件,怎么清除DNS缓存
  9. 设计模式:单件模式(Singleton Pattern)
  10. 内存的工作原理(一)
  11. Eclipse 在开发中使用到的快捷键很实用 .
  12. zuul压力测试与调优
  13. ROI与CPC、CPM有什么关系
  14. CoolFire系列讲座 第2讲
  15. 示波器使用方法入门之道
  16. Hypergraph Neural Networks超图神经网络
  17. Android - View 和 ViewGroup
  18. 语音识别特征处理(MFCC,Fbank,PNCC)
  19. 平板为何无法用无线网连接媒体服务器,我家装了无线路由器后,台式机老是断网但是平板电脑却能连接无线网络上网...
  20. wp模板里面的各种判断

热门文章

  1. 基于Myrocks和spider构建分布式数据库
  2. 60位移动游戏大佬共同发起成立“上方汇”
  3. js监听只读文本框_js设置input文本框只读
  4. keras求两向量间的余弦值
  5. mysql5.7架设征途服务器_征途手工架设服务端+配套双客户端+架设流程
  6. 桌面池计算机置备,Horizon View 7 发布Win10桌面二:即时克隆桌面池配置
  7. windows10_小屏幕显示不可调整的大窗口(老软件)/widows字体大小调整
  8. H5微信授权登录 H5支付 外部浏览器微信支付 前端一个函数搞
  9. java implode函数_PHP警告:implode():传递的参数无效
  10. JavaFx-桌面应用开发利器(二)基础架构篇