iis服务器助手广告广告
返回顶部
首页 > 资讯 > 精选 >Ajax和form+iframe怎么实现文件上传
  • 179
分享到

Ajax和form+iframe怎么实现文件上传

2023-06-08 08:06:52 179人浏览 安东尼
摘要

这篇文章将为大家详细讲解有关ajax和fORM+iframe怎么实现文件上传,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。HTML5Ajax上传HTML5的上传实现,是需要file控件以及XMLHttpR

这篇文章将为大家详细讲解有关ajax和fORM+iframe怎么实现文件上传,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

HTML5Ajax上传

HTML5的上传实现,是需要file控件以及XMLHttpRequest请求。下面是我封装的一个上传插件

function fileUpload(options) {var opts = options || {};var func = function() {};this.fileInput = opts.fileInput || null;this.url = opts.url || '';this.fileList = [];this.onFilter = opts.onFilter || function(f) {return f;}; //选择文件组的过滤方法this.onSelect = opts.onSelect || func; //文件选择后this.onProgress = opts.onProgress || func; //文件上传进度this.onSuccess = opts.onSuccess || func; //文件上传成功时this.onFailure = opts.onFailure || func; //文件上传失败时;this.onComplete = opts.onComplete || func; //文件全部上传完毕时this.init();}fileUpload.prototype = {dealFiles: function(e) { //获取要上传的文件数组(用户选择文件后执行)var files = e.target.files || e.dataTransfer.files;this.fileList = this.onFilter(files);for(var i = 0, file; file = this.fileList[i]; i++){ //增加唯一索引值file.index = i;}this.onSelect(this.fileList);return this;},removeFile: function(fileDelete) { //删除某一个文件var arrFile = [];for(var i = 0, file; file = this.fileList[i]; i++){if (file != fileDelete) {arrFile.push(file);}}this.fileList = arrFile;return this;},removeAll: function() { //清空文件队列this.fileList = [];return this;},uploadFile: function() { //上传文件var me = this;for(var i = 0, file; file = this.fileList[i]; i++){(function(file) {var formData = new FormData();var xhr = new XMLHttpRequest();if (xhr.upload) {xhr.upload.addEventListener("progress", function(e) { // 上传中me.onProgress(file, e.loaded, e.total);}, false);xhr.onreadystatechange = function(e) { // 文件上传成功或是失败if (xhr.readyState == 4) {if (xhr.status == 200) {me.onSuccess(file, xhr.responseText);me.removeFile(file);if (!me.fileList.length) {me.onComplete(); //上传全部完毕。执行回调}} else {me.onFailure(file, xhr.responseText);}}};// 开始上传formData.append('file', file);xhr.open("POST", me.url, true);xhr.send(formData);}})(file);}},init: function() {var me = this;//文件选择控件选择if (me.fileInput) {me.fileInput.addEventListener("change", function(e) { me.dealFiles(e); }, false);}}};

相信大家也看到了,代码中出现了formData,这就是html5的神奇之处了。借助formData轻松实现异步无刷新支持预览图片的多文件上传功能。而且,令人欣慰的是,现在已经有很多浏览器都已经支持html5了。

但是!!!ie9以下的版本不支持呀!!

除此之外,上面的方法还有一个弊端,因为使用了ajax的上传方式,所以不能支持跨域上传,如果必须要满足这两个业务场景,那就试试下面的方法吧,借助form和iframe来实现上传。下面来详细看一下:

form表单提交到iframe

html代码:

<iframe name="demoIframe" ></iframe><form target="demoIframe" action="upload.PHP" method="post" enctype="multipart/form-data"><input class="filename" type="file" name="fileLabel"><input type="submit" value="提交"></form>

我们点击提交,可以看到下面的请求:

Ajax和form+iframe怎么实现文件上传

已经把文件上传。那么,加入这个upload.php接口可用,而且假如上传成功后,会返回:

{"code": "200","success": true,"data": {...}}

我们要怎么去获取返回值,从而进行下一步的操作呢?因为我们是上传到了iframe中,所以我们只需要监听iframe的load事件,如果有返回值了,我们就能获取到,从而进行进一步处理。看js代码:

$('iframe').on('load', function() {var responseText = $('iframe')[0].contentDocument.body.textContent;var responseData = JSON.parse(responseText) || {};if (responseData.isSuccess == true || responseData.code == 200) {//success} else {//error }});

关于“Ajax和form+iframe怎么实现文件上传”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

--结束END--

本文标题: Ajax和form+iframe怎么实现文件上传

本文链接: https://www.lsjlt.com/news/252827.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • c++中if elseif使用规则
    c++ 中 if-else if 语句的使用规则为:语法:if (条件1) { // 执行代码块 1} else if (条件 2) { // 执行代码块 2}// ...else ...
    99+
    2024-05-14
    c++
  • c++中的继承怎么写
    继承是一种允许类从现有类派生并访问其成员的强大机制。在 c++ 中,继承类型包括:单继承:一个子类从一个基类继承。多继承:一个子类从多个基类继承。层次继承:多个子类从同一个基类继承。多层...
    99+
    2024-05-14
    c++
  • c++中如何使用类和对象掌握目标
    在 c++ 中创建类和对象:使用 class 关键字定义类,包含数据成员和方法。使用对象名称和类名称创建对象。访问权限包括:公有、受保护和私有。数据成员是类的变量,每个对象拥有自己的副本...
    99+
    2024-05-14
    c++
  • c++中优先级是什么意思
    c++ 中的优先级规则:优先级高的操作符先执行,相同优先级的从左到右执行,括号可改变执行顺序。操作符优先级表包含从最高到最低的优先级列表,其中赋值运算符具有最低优先级。通过了解优先级,可...
    99+
    2024-05-14
    c++
  • c++中a+是什么意思
    c++ 中的 a+ 运算符表示自增运算符,用于将变量递增 1 并将结果存储在同一变量中。语法为 a++,用法包括循环和计数器。它可与后置递增运算符 ++a 交换使用,后者在表达式求值后递...
    99+
    2024-05-14
    c++
  • c++中a.b什么意思
    c++kquote>“a.b”表示对象“a”的成员“b”,用于访问对象成员,可用“对象名.成员名”的语法。它还可以用于访问嵌套成员,如“对象名.嵌套成员名.成员名”的语法。 c++...
    99+
    2024-05-14
    c++
  • C++ 并发编程库的优缺点
    c++++ 提供了多种并发编程库,满足不同场景下的需求。线程库 (std::thread) 易于使用但开销大;异步库 (std::async) 可异步执行任务,但 api 复杂;协程库 ...
    99+
    2024-05-14
    c++ 并发编程
  • 如何在 Golang 中备份数据库?
    在 golang 中备份数据库对于保护数据至关重要。可以使用标准库中的 database/sql 包,或第三方包如 github.com/go-sql-driver/mysql。具体步骤...
    99+
    2024-05-14
    golang 数据库备份 mysql git 标准库
  • 如何在 Golang 中优雅地处理错误?
    在 go 中,优雅处理错误包括:使用 error 类型;使用 errors 包函数和类型;自定义错误类型;遵循错误处理模式,包括关闭资源、检查错误、打印错误信息和处理或返回错误。 在 ...
    99+
    2024-05-14
    golang 错误处理
  • 如何构建 Golang RESTful API,并使用中间件进行身份验证?
    本文介绍了如何构建 golang restful api。首先,通过导入必要的库、定义数据模型和创建路由来构建 restful api。其次,使用 go-chi/chigot 和 go-...
    99+
    2024-05-14
    golang git
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作