失眠网,内容丰富有趣,生活中的好帮手!
失眠网 > jQuery Ajax使用FormData上传文件和其他数据实例详解

jQuery Ajax使用FormData上传文件和其他数据实例详解

时间:2018-11-10 23:11:02

相关推荐

jQuery Ajax使用FormData上传文件和其他数据实例详解

web前端|js教程

FormData,jQuery,Ajax

web前端-js教程

这篇文章主要介绍了jQuery Ajax使用FormData上传文件和其他数据后端web.py获取 ,需要的朋友可以参考下,希望能帮助到大家。

php网站源码论坛,vscode网页版教程,ubuntu cvt命令,tomcat 孙卫琴,sqlite3 关键字,高楼层发现大爬虫怎么办,php 获取txt,seo实战免费课程分类,备案的网站程序上传,带号模板下载安装lzw

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

猜谜游戏源码,vscode设置编码,ubuntu 13.04,tomcat 内存配置,sqlite 删除所有,网页设计培训班 网页设计学校,asp连接sql数据库,云服务器跟虚拟主机,chart图形插件,Web前端框架mvc,爬虫代理ip池,php文件打开,河北seo,springboot的引言,网页标签大全,92game最新仿制迅播网站源码,网页制作教程 html5,wp模板 瀑布流主题,4006后台,div不同页面跳转,asp人事管理系统源码包,表情识别程序开发lzw

jQuery 2.0+的版本支持FormData

易语言玫瑰花表白源码,vscode怎么编写,ubuntu安装图片服务器,tomcat 服务无法,sqlite没有日期类型,qq浮动插件,前端框架构思设计,网络爬虫基本术语,php面向对象的编程,ios seo,html网站建设源码,给女朋友做网页源代码,网站模板样式修改,访客登记小程序lzw

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

•前端(JQuery):

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 () {} }); }

•后台(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.

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

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

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

方法二√:不用

,使用FormData对象添加字段方式上传文件

有时,我们并不想用

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

•前端(JQuery):

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.没有

标签(有了也不错)

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

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

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

HTML里FormData对象的详细介绍

使用FormData提交表单及上传图片的方法

JavaScript中FormData 在对象运用

如果觉得《jQuery Ajax使用FormData上传文件和其他数据实例详解》对你有帮助,请点赞、收藏,并留下你的观点哦!

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。