• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com专业计算机教程网站
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure
您的位置:首页 > 网页设计 >html5 > 基于HTML5的可预览多图片Ajax上传

基于HTML5的可预览多图片Ajax上传

作者:mozuncangtianbaxue的博客 字体:[增加 减小] 来源:互联网 时间:2017-08-21

本文主要包含html5,图片上传等相关知识,mozuncangtianbaxue的博客希望在学习及工作中可以帮助到您

 

一、关于图片上传什么什么的

 

在XHTML的时代,我们使用HTML file控件上传图片一次只能上传一张。要一次上传多图,做法是借助于flash。例如swfupload.js。可惜,使用复杂的点,比如flash文件需与页面同父文件夹,JavaScript文件大小也很可观。

我之前曾翻译编辑过一篇“Ajax Upload多文件上传插件”的文章,此插件的亮点是使用隐藏的iframe框架页面模拟ajax上传,但是,实际上,还是一次只能上传1张图片,可以多次上传而已。

HTML5是个好东东,其中之一就是支持多图片上传,而且支持ajax上传,而且支持上传之前图片的预览,而且支持图片拖拽上传,纯粹利用file控件实现,JS代码寥寥,想不让人称赞都难啊!

二、demo页面

如果您手头上的浏览器是最新的FireFox或是Chrome浏览器,您可以狠狠地点击这里:基于HTML5的多图Ajax上传demo

在demo页面中,您可以点击file控件上传多图,如下(FireFox 6截图示意,下同):
选择多图 张鑫旭-鑫空间-鑫生活

如果有非图片文件或是图片尺寸过大,会弹出提示:
不符合要求文件提示 张鑫旭-鑫空间-鑫生活

或者您可以直接将桌面上的图片拖到接受拖拽的区域处:
图片拖拽示意 张鑫旭-鑫空间-鑫生活

释放后图片就可以直接预览了(此时还未上传到服务器上):
图片上传前预览 张鑫旭-鑫空间-鑫生活

此时图片可提前删除,也可以直接上传,例如,我们点击上传按钮,很快的,图片上传成功啦:)!

图片上传中进度显示示意 张鑫旭-鑫空间-鑫生活

上传后的页面地址就返回了,如下:
图片上传成功后返回的地址 张鑫旭-鑫空间-鑫生活

此时,对应的upload文件夹下面这张图片就有了:
文件夹下面上传的对应图片张鑫旭-鑫空间-鑫生活

注意:鄙人博客空间大小有限,我会定时清理该图片文件夹,so, 诸位不要把这里当做免费的图片托管场所哦~~

三、核心骨架脚本简单剖析

首先是文件上传的一个core文件,是前两个晚上慢慢吞吞整出来的。文件名是: zxxFile.js (可右键……下载)

此文件就几K,百来行代码,主要负责文件上传相关的逻辑(选择、删除之类),原生JS,因此,兼容jQuery,YUI, MooYools等。zxxFile.js其实是个小巧的骨架文件,肉体等则需要另外添加。

zxxFile.js其实就是个小小对象而已:

var ZXXFILE = {
    //骨架们...
}

下表显示为ZXXFILE对象的属性(骨架)及其对应的内容含义等。

属性或方法 默认方法或值 释义
fileInput null DOM元素。表file控件元素。
dragDrop null DOM元素。表拖放感应区域元素。
upButton null DOM元素。提交的按钮元素。
url "" 字符串。表示文件ajax上传的地址
fileFilter [] 过滤后的文件对象数组,一般不参与初始化。可用来判断当前列表的数目。
filter function(files) {
  return files; 
}
函数。用来过滤选择的文件列表。例如只能是选择图片,或是大小尺寸限制等。支持一个参数(files),为文件对象数组,需返回数组。
onSelect function() {} 函数。当本地文件被选择之后执行的回调。支持一个参数(files),为文件对象数组。
onDelete function() {} 函数。当某一个上传文件上传成功之后(自动)或被删除(手动)的时候执行的方法。接受一个参数(file),表当前删除文件。
onDragOver function() {} 函数。当本地文件被拖到拖拽敏感元素上面时执行的方法。方法中的this指该敏感元素,也就是上面的dragDrop元素。
onDragLeave function() {} 函数。当本地文件离开拖拽敏感元素时执行的方法。方法中的this指该敏感元素,也就是上面的dragDrop元素。
onProgress function() {} 函数。文件上传过程中执行的回调方法。接受三个参数(file, loaded, total),分别表示当前上传文件对象,已上传字节数,文件总字节数。
onSuccess function() {} 函数。当前文件上传成功执行的回调方法。接受两个参数(file, response),表示当前上传成功的文件对象和后台返回的字符内容。
onFailure function() {} 函数。当前文件上传失败执行的回调方法。接受两个参数(file, response),表示当前上传失败的文件对象和后台返回的字符内容。
onComplete function() {} 函数。当前文件对象列表全部上传完毕执行的回调方法。无可用参数。
funDragHover 略 方法。文件拖拽相关。非可用API。
funGetFiles 略 方法。获取选择或拖拽文件。非可用API。
funDealFiles 略 方法。对选择文件进行处理。非可用API。
funDeleteFile 略 方法。删除列表中的某个文件。外部可用API,在手动删除某文件时需调用此方法。
funUploadFile 略 方法。文件上传相关。非可用API。
init 略 方法。初始化,主要是一个元素的事件绑定。非可用API。

补充说明:上面多次提到的file参数指的是file object对象,该对象的属性值有name, size, type等,然后,在zxxFile.js中,其还多了个方便元素定位的index索引属性。

显然,只有骨架基本上做不了什么事件。demo页面之所以有效果,就是其按照上面的骨架,根据实际的需求增加了血肉。您可以直接“右键-查看页面源代码”一览所有相关JavaScript。或者看我下面一点一点婆妈的讲述。

我们按照上面表格中

您可能想查找下面的文章:

  • HTML5知识点总结
  • HTML5的本地存储
  • HTML5本地存储之IndexedDB
  • Html5实现文件异步上传功能
  • Html5新标签datalist实现输入框与后台数据库数据的动态匹配
  • 详解HTML5 window.postMessage与跨域
  • HTML5拖放API实现拖放排序的实例代码
  • 解决html5中video标签无法播放mp4问题的办法
  • HTML5新特性 多线程(Worker SharedWorker)
  • Html5新增标签有哪些

相关文章

  • 2017-08-06HTML5 在canvas中绘制矩形附效果图
  • 2018-12-03html5中新特性之语义化标签的实例分析
  • 2018-12-03不刷新的前提下怎样改变当前url的代码
  • 2018-12-03HTML5不支持标签和新增标签详解
  • 2018-12-03总结Html5表单(二) input type 各种输入, 各种用户选择,上传
  • 2017-08-06Html5元素及基本语法详解
  • 2017-08-06Html5实现iPhone开机界面示例代码
  • 2018-12-03HTMl5的存储方式sessionStorage和localStorage详解_html5教程技巧
  • 2018-12-03HTML5的download属性详细介绍和使用实例_html5教程技巧
  • 2018-12-03基于HTML5 FileSystem API的使用介绍_html5教程技巧

文章分类

  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure

最近更新的内容

    • HTML5标签小集
    • HTML的基本结构与标签的初步了解
    • HTML 5基础之HTML 5 API的威力
    • 用HTML5来开发一款android本地化App游戏-宝石碰碰
    • HTML5 input placeholder 颜色修改示例
    • HTML5 画布canvas使用方法_html5教程技巧
    • HTML5离线缓存Manifest是什么
    • H5学习之旅-H5的新特性(1)
    • 如何使用html5与css3完成google涂鸦动画
    • HTML5 用动画的表现形式装载图像 _html5教程技巧

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有