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实现div跟随鼠标移动
Aug 20 jQuery
360提示[高危]使用存在漏洞的JQuery版本的解决方法
Oct 27 jQuery
原生JS与jQuery编写简单选项卡
Oct 30 jQuery
jquery应用实例分享_实现手风琴特效
Feb 01 jQuery
jQuery中内容过滤器简单用法示例
Mar 31 jQuery
jQuery中的$是什么意思及 $. 和 $().的区别
Apr 20 jQuery
jQuery+ajax实现动态添加表格tr td功能示例
Apr 23 jQuery
jQuery超简单遮罩层实现方法示例
Sep 06 jQuery
jQuery实现获取当前鼠标位置并输出功能示例
Jan 05 jQuery
jQuery 筛选器简单操作示例
Oct 02 jQuery
JQuery使用属性addClass、removeClass和toggleClass实现增加和删除类操作示例
Nov 18 jQuery
JavaScript或jQuery 获取option value值方法解析
May 12 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排序算法的复习和总结
2012/02/15 PHP
php 模拟post_验证页面的返回状态(实例讲解)
2013/10/28 PHP
PHP屏蔽过滤指定关键字的方法
2014/11/03 PHP
jquery 打开窗口返回值实现代码
2010/03/04 Javascript
限制文本框输入N个字符的js代码
2010/05/13 Javascript
instanceof和typeof运算符的区别详解
2014/01/06 Javascript
node.js中的fs.ftruncate方法使用说明
2014/12/15 Javascript
Js可拖拽放大的层拖动特效实现方法
2015/02/25 Javascript
浅谈利用JavaScript进行的DDoS攻击原理与防御
2015/06/04 Javascript
js实现完美兼容各大浏览器的人民币大小写相互转换
2015/10/29 Javascript
JavaScript如何禁止Backspace键
2015/12/02 Javascript
浅谈javascript中的constructor
2016/06/08 Javascript
javascript淘宝主图放大镜功能
2016/10/20 Javascript
浅谈angularjs module返回对象的坑(推荐)
2016/10/21 Javascript
深入学习Bootstrap表单
2016/12/13 Javascript
jQuery Autocomplete简介_动力节点Java学院整理
2017/07/17 jQuery
ES2020 新特性(种草)
2020/01/12 Javascript
vue 调用 RESTful风格接口操作
2020/08/11 Javascript
通过实例解析json与jsonp原理及使用方法
2020/09/27 Javascript
小小聊天室Python代码实现
2016/08/17 Python
python3.5 + PyQt5 +Eric6 实现的一个计算器代码
2017/03/11 Python
python实现祝福弹窗效果
2019/04/07 Python
python读取mysql数据绘制条形图
2020/03/25 Python
opencv 图像滤波(均值,方框,高斯,中值)
2020/07/08 Python
ECCO爱步美国官网:来自丹麦的鞋履品牌
2016/11/23 全球购物
党员培训思想汇报
2014/01/07 职场文书
调解员先进事迹材料
2014/02/07 职场文书
幼儿园秋游感想
2014/03/12 职场文书
2014中考励志标语
2014/06/05 职场文书
2014年社区宣传工作总结
2014/12/02 职场文书
警示教育观后感
2015/06/17 职场文书
总经理聘用协议书
2015/09/21 职场文书
成本低的5个创业项目:投资小、赚钱快
2019/08/20 职场文书
python基础之停用词过滤详解
2021/04/21 Python
CSS3实现列表无限滚动/轮播效果
2021/06/23 HTML / CSS
python游戏开发之pygame实现接球小游戏
2022/04/22 Python