jquery使用FormData实现异步上传文件


Posted in jQuery onOctober 25, 2018

考虑一个常见的用户上传头像的场景:

  • 点击按钮,弹出文件选择框
  • 选中图片并确认后直接上传图片

实现这个功能,需要使用<input>来添加文件,并实现上传功能。传统的上传文件是将<input>放到<form>中提交,但在这个场景中并不存在form表单,只有一个input而已。那么应该如何处理呢?

答案是可以使用FormData来实现文件的提交。

先看一下MDN对FormData的介绍:

XMLHttpRequest Level 2添加了一个新的接口FormData.利用FormData对象,我们可以通过JavaScript用一些键值对来模拟一系列表单控件,我们还可以使用XMLHttpRequest的send()方法来异步的提交这个”表单”.比起普通的ajax,使用FormData的最大优点就是我们可以异步上传一个二进制文件.

这样一来,解决问题的思路就出来了:

  • 每次选中文件并确认后,<input>会触发change事件,在onchange事件处理函数中处理即可。
  • 创建一个FormData对象,并将选中的文件追加进去。
  • 使用Ajax发送这个FormData对象。

下面用一个Demo展示具体的代码实现用FormData将文件发送到一个php:

<html>
<head>
  <title>Upload</title>
  <meta charset="utf-8">
</head>
<body>
  <input id="file-input" type="file">

  <script>
    var input = document.getElementById('file-input');
    input.onchange = function () {
      var data = new FormData();
      data.append('file', input.files[0]);

      var request = new XMLHttpRequest();
      request.open('POST', './upload.php');
      request.send(data);
    };
  </script>
</body>
</html>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

jQuery 相关文章推荐
jQuery实现的背景颜色渐变动画效果示例
Mar 24 jQuery
jQuery中map函数的两种方式
Apr 07 jQuery
jQuery滑动到底部加载下一页数据的实例代码
May 22 jQuery
实现jquery放大镜的两种方法
Feb 22 jQuery
JS文件中加载jquery.js的实例代码
May 05 jQuery
jQuery+PHP实现上传裁剪图片
Jun 29 jQuery
jquery插件开发模式实例详解
Jul 20 jQuery
jquery向后台提交数组的代码分析
Feb 20 jQuery
JQuery事件冒泡和默认行为代码实例
May 13 jQuery
jquery简易手风琴插件的封装
Oct 13 jQuery
多种类型jQuery网页验证码插件代码实例
Jan 09 jQuery
jquery插件实现悬浮的菜单
Apr 24 jQuery
jQuery+Datatables实现表格批量删除功能【推荐】
Oct 24 #jQuery
jQuery pagination分页示例详解
Oct 23 #jQuery
jquery.pagination.js分页使用教程
Oct 23 #jQuery
jquery分页插件pagination使用教程
Oct 23 #jQuery
使用jquery Ajax实现上传附件功能
Oct 23 #jQuery
jquery实现动态添加附件功能
Oct 23 #jQuery
jQuery.validate.js表单验证插件的使用代码详解
Oct 22 #jQuery
You might like
一个简单的网页密码登陆php代码
2012/07/17 PHP
PHP类的反射用法实例
2014/11/03 PHP
PHP+swoole实现简单多人在线聊天群发
2016/01/19 PHP
PHP getallheaders无法获取自定义头(headers)的问题
2016/03/23 PHP
用javascript获得地址栏参数的两种方法
2006/11/08 Javascript
面向对象的javascript(笔记)
2009/10/06 Javascript
JQuery 遮罩层实现(mask)实现代码
2010/01/09 Javascript
用jQuery toggleClass 实现鼠标移上变色
2014/05/14 Javascript
在JavaScript中操作时间之setYear()方法的使用
2015/06/12 Javascript
Google 地图获取API Key详细教程
2016/08/06 Javascript
jQuery自定义插件详解及实例代码
2016/12/29 Javascript
详解angular中如何监控dom渲染完毕
2017/01/03 Javascript
微信小程序 实战程序简易新闻的制作
2017/01/09 Javascript
React-router中结合webpack实现按需加载实例
2017/05/25 Javascript
React学习笔记之事件处理(二)
2017/07/02 Javascript
JQ图片文件上传之前预览功能的简单实例(分享)
2017/11/12 Javascript
Vue axios设置访问基础路径方法
2018/09/19 Javascript
jquery 遍历hash操作示例【基于ajax交互】
2019/10/12 jQuery
javascript操作元素的常见方法小结
2019/11/13 Javascript
three.js 将图片马赛克化的示例代码
2020/07/31 Javascript
vue实现前端列表多条件筛选
2020/10/26 Javascript
python操作CouchDB的方法
2014/10/08 Python
用Python计算三角函数之acos()方法的使用
2015/05/15 Python
python executemany的使用及注意事项
2017/03/13 Python
使用Python读取大文件的方法
2018/02/11 Python
PyQt5实现画布小程序
2020/05/30 Python
BIBLOO捷克:购买女装、男装、童装、鞋和配件
2017/01/27 全球购物
百丽国际旗下购物网站:优购
2017/02/28 全球购物
澳大利亚拥有最佳跳伞降落点和最好服务的跳伞项目运营商:Skydive Australia
2018/03/05 全球购物
Shell如何接收变量输入
2016/08/06 面试题
高一学生评语大全
2014/04/25 职场文书
2014年党员加强作风建设思想汇报
2014/09/15 职场文书
习近平在党的群众路线教育实践活动总结大会上的讲话全文
2014/10/25 职场文书
2015会计试用期工作总结
2014/12/12 职场文书
网络营销计划书
2015/01/17 职场文书
烟台的海导游词
2015/02/02 职场文书