jQuery Ajax使用FormData上传文件和其他数据后端web.py获取


Posted in jQuery onJune 11, 2017

XMLHttpRequest Level 2 添加了一个新的接口——FormData。与普通的 Ajax 相比,使用 FormData 的最大优点就是我们可以异步上传二进制文件。

jQuery 2.0+的版本支持FormData

方法一:使用<form>表单初始化FormData对象方式上传文件

•前端(JQuery):

<form enctype="multipart/form-data">
  <input type="file" name="myfile" onchange="loadFile(this.files[0])">
</form>
<script>
  function loadFile(file){
    var formdata = new FormData($$('form')[0]);
    $.ajax({
      url: 'jobs/add',
      type: 'POST',
      datatype: 'json',
      data: formdata,
      cache:false,
      traditional: true,
      contentType: false,
      processData: false,
      success: function (data) {},
      error: function () {}
    });
  }
</script>

•后台(web.py):

class Add:
  def POST(self):
    i = web.input(myfile={})
    print(i['myfile'].filename) #文件名
    print(i['myfile'].value) #文件内容
    print(i['myfile'].file.read()) #文件内容

 注意:

1.<form>的enctype属性需要设置为“multipart/form-data”

2.$.ajax中processData、contentType和cache需要设置为false

3.后端通过web.input获取文件的字段名,同前端指定的input标签的name属性

方法二√:不用<form>,使用FormData对象添加字段方式上传文件

有时,我们并不想用

标签,而且通过ajax传给后端的并不只有文件,可能还有其他的键值对,这时就可以用这个方法

•前端(JQuery):

<input type="file" onchange="loadFile(this.files[0])" />
function loadFile(file){
  container.fd = new FormData();
  container.fd.append('myfile',file);
  container.fd.append('otherkey',othervalue);
  $.ajax({
    url: 'jobs/add',
    type: 'POST',
    datatype: 'json',
    data: fd,
    cache:false,
    traditional: true,
    contentType: false,
    processData: false,
    success: function (data) {},
    error: function () {}
  });
}

•后台(web.py):

class Add:
  def POST(self):
    i = web.input(myfile={}, otherkey='')
    print(i['myfile'].filename) #文件名
    print(i['myfile'].value) #文件内容
    print(i['myfile'].file.read()) #文件内容

 注意:

1.没有<form>标签(有了也不错)

2.append()方法的第二个参数是文件对象,在html中已经通过loadFile方法的参数传过来

3.后端通过web.input获取文件的字段名,同前端append()方法的第一个参数

4.因为通过web.input获取的值都是字符串,如果除文件以外的键值对传过来是null,会自动转化为字符串'null'。这点处理的时候需要注意

以上所述是小编给大家介绍的jQuery Ajax使用FormData上传文件和其他数据后端web.py获取,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的!

jQuery 相关文章推荐
jQuery插件FusionCharts绘制2D双折线图效果示例【附demo源码】
Apr 14 jQuery
jQuery中的deferred对象和extend方法详解
May 08 jQuery
jQuery validata插件实现方法
Jun 25 jQuery
jQuery实现html table行Tr的复制、删除、计算功能
Jul 10 jQuery
jQuery实现checkbox的简单操作
Nov 18 jQuery
vue-cli webpack 引入jquery的方法
Jan 10 jQuery
[jQuery] 事件和动画详解
Mar 05 jQuery
解决JQuery的ajax函数执行失败alert函数弹框一闪而过问题
Apr 10 jQuery
jquery实现下载图片功能
Jul 18 jQuery
jQuery+css实现的点击图片放大缩小预览功能示例【图片预览 查看大图】
May 29 jQuery
jquery插件实现轮播图效果
Oct 19 jQuery
jquery自定义组件实例详解
Dec 31 jQuery
jQuery复合事件结合toggle()方法的用法示例
Jun 10 #jQuery
jQuery复合事件用法示例
Jun 10 #jQuery
jQuery简单绑定单个事件的方法示例
Jun 10 #jQuery
jQuery正则验证注册页面经典实例
Jun 10 #jQuery
JQuery form表单提交前验证单选框是否选中、删除记录时验证经验总结(整理)
Jun 09 #jQuery
JQuery.dataTables表格插件添加跳转到指定页
Jun 09 #jQuery
jQuery为某个div加入行样式
Jun 09 #jQuery
You might like
PHP求小于1000的所有水仙花数的代码
2012/01/10 PHP
php长字符串定义方法
2012/07/12 PHP
PHP操作Memcache实例介绍
2013/06/14 PHP
php计算程序运行时间的简单例子分享
2014/05/10 PHP
PHP使用trim函数去除字符串左右空格及特殊字符实例
2016/01/07 PHP
thinkPHP多域名情况下使用memcache方式共享session数据的实现方法
2016/07/21 PHP
功能强大的PHP发邮件类
2016/08/29 PHP
基于jQueryUI和Corethink实现百度的搜索提示功能
2016/11/09 PHP
php学习笔记之mb_strstr的基本使用
2018/02/03 PHP
Jsonp 跨域的原理以及Jquery的解决方案
2011/06/27 Javascript
Dom操作之兼容技巧分享
2011/09/20 Javascript
js特殊字符转义介绍
2013/11/05 Javascript
jQuery中:last选择器用法实例
2014/12/30 Javascript
DOM节点深度克隆函数cloneNode()用法实例
2015/01/12 Javascript
javascript事件冒泡和事件捕获详解
2015/05/26 Javascript
利用jQuery和CSS将背景图片拉伸
2015/10/16 Javascript
jquery实现简易的移动端验证表单
2015/11/08 Javascript
详解微信小程序 template添加绑定事件
2017/06/23 Javascript
Vue渲染函数详解
2017/09/15 Javascript
JavaScript简单实现合并两个Json对象的方法示例
2017/10/16 Javascript
微信小程序实现打开内置地图功能【附源码下载】
2017/12/07 Javascript
jQuery实现菜单的显示和隐藏功能示例
2018/07/24 jQuery
浅谈webpack4 图片处理汇总
2018/09/12 Javascript
详解vue-template-admin三级路由无法缓存的解决方案
2020/03/10 Javascript
《javascript设计模式》学习笔记七:Javascript面向对象程序设计组合模式详解
2020/04/08 Javascript
python使用beautifulsoup从爱奇艺网抓取视频播放
2014/01/23 Python
python批量添加zabbix Screens的两个脚本分享
2017/01/16 Python
PyQt5固定窗口大小的方法
2019/06/18 Python
Python如何筛选序列中的元素的方法实现
2019/07/15 Python
Python sorted排序方法如何实现
2020/03/31 Python
用CSS3写的模仿iPhone中的返回按钮
2015/04/04 HTML / CSS
迪卡侬比利时官网:Decathlon比利时
2019/12/28 全球购物
运动会通讯稿150字
2014/02/15 职场文书
浪漫婚礼主题活动策划方案
2014/09/15 职场文书
检讨书格式
2015/05/07 职场文书
前端监听websocket消息并实时弹出(实例代码)
2021/11/27 Javascript