• 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上传

作者:匿名 字体:[增加 减小] 来源:互联网 时间:2018-12-03

本文主要包含Ajax 上传 html5等相关知识,匿名希望在学习及工作中可以帮助到您
一、关于图片上传什么什么的

在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截图示意,下同):

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

如果有非图片文件或是图片尺寸过大,会弹出提示:

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

或者您可以直接将桌面上的图片拖到接受拖拽的区域处:

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

释放后图片就可以直接预览了(此时还未上传到服务器上):

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

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

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

上传后的页面地址就返回了,如下:

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

此时,对应的upload文件夹下面这张图片就有了:

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

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

三、核心骨架脚本简单剖析
首先是文件上传的一个core文件,是前两个晚上慢慢吞吞整出来的。文件名是: zxxFile.js (可右键……下载)

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

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

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

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

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

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

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

我们按照上面表格中的骨架进行示意。demo页面借用了比较流行的jQuery库,骨架+血肉 = 插件,当然,demo页面并不是奔着插件去的(虽然只需稍加修改),因为页面的UI显然不够插件的份。也就是说,利用zxxFile.js骨架,配合点你自己属性的JavaScript库就可以书写属于你自己的基于HTML5的多文件Ajax上传插件啦!

四、demo页面的些代码
demo页面代码整体逻辑如下:

var params = {
  //血肉们
};
ZXXFILE = $.extend(ZXXFILE, params);
ZXXFILE.init();

fileInput
首先是file控件元素,如下:

fileInput: $("#fileImage").get(0)
因为是DOM元素,所以应用了jQuery的get方法。下面两个参数同。

demo页面中的file控件元素支持多文件选择,其隐藏的玄机就是下面代码中大红高亮的部分:

<input id="fileImage" type="file" size="30" name="fileselect[]" multiple />

dragDrop和upButton
拖拽区域和上传按钮(默认隐藏):

dragDrop: $("#fileDragArea").get(0),
upButton: $("#fileSubmit").get(0)

url
Ajax上传地址,没什么好说的,取的是表单的action地址:

url: $("#uploadForm").attr("action")

filter方法
对选择的文件进行过滤。file控件什么文件都能选,而demo页面是图片上传相关的demo;空间大小有限,超大尺寸的图片还是挡着为好。显然,要对上传文件进行过滤。于是,就有了如下的过滤脚本:

filter: function(files) {
  var arrFiles = [];
  for (var i = 0, file; file = files[i]; i++) {
    if (file.type.indexOf("image") == 0) {
      if (file.size >= 512000) {
        alert('您这张"'+ file.name +'"图片大小过大,应小于500k'); 
      } else {
        arrFiles.push(file); 
      }  
    } else {
      alert('文件"' + file.name + '"不是图片。'); 
    }
  }
  return arrFiles;
}

zxxFile.js会自动对过滤后的文件对象列表进行整合,以准确上传。

onSelect方法
文件(这里就是图片)选择后执行的方法。在本实例页面中,onSelect方法的主要任务就是本地图片在浏览器中的预览。本地图片上传之前在浏览器中预览的核心脚本就是:

var reader = new FileReader(), htmlImage;
reader.onload = function(e) {
  htmlImage = '<img src="'+ e.target.result +'" />';
}
reader.readAsDataURL(file);

在本demo页面中,该部分完成脚本如下,虽好像有些长度,其实内容就是装载一些HTML代码而已:

onSelect: function(files) {
  var html = '', i = 0;
  //等待载入gif动画
  $("#preview").html('<p class="upload_loading"></p>');
  var funAppendImage = function() {
    file = files[i];
    if (file) {
      var reader = new FileReader()
      reader.onload = function(e) {
        html = html + '<p id="uploadList_'+ i +'" class="upload_append_list"><p><strong>' + file.name + '</strong>'+ 
          '<a href="javascript:" class="upload_delete" title="删除" data-index="'+ i +'">删除</a><br />' +
          '<img id="uploadImage_' + i + '" src="' + e.target.result + '" class="upload_image" /></p>'+ 
          '<span id="uploadProgress_' + i + '" class="upload_progress"></span>' +
        '</p>';
        
    
  


 

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

相关文章

  • 2018-12-03HTML5实践-使用css制作时间ICON的具体详解(图)
  • 2018-12-03html5 初试 indexedDB(推荐)
  • 2017-08-06HTML5 video标签(播放器)学习笔记(一):使用入门
  • 2018-12-03HTML5 WebSocket实现聊天室的代码示例
  • 2018-12-03html5 利用canvas实现超级玛丽简单动画_html5教程技巧
  • 2018-12-03phonegap实现进行本地存储的方法介绍
  • 2018-12-03html5 datalist标签的用法是什么?这里有datalist标签的用法实例
  • 2018-12-03生日蛋糕的制作方法-不过用的是HTML5+CSS3代码
  • 2018-12-03H5实现旋转立体魔方
  • 2018-12-03HTML 5 event-source 标签是否违背了自定义标签才使用短横线的约定?

文章分类

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

最近更新的内容

    • 小强的HTML5移动开发之路(12)——从一个多媒体标签说起
    • HTML5资源预加载(Link prefetch)详细介绍(给你的网页加速)_html5教程技巧
    • HTML5面向对象的游戏开发简单实例分享
    • HTML5实现移动端自适应的几种方法介绍
    • 简单整理HTML5的基本特性和语法_html5教程技巧
    • HTML5--多媒体标签详解
    • css3 transform 3d 使用css3创建动态3d立方体(html5实践)
    • HTML5学习笔记(四)-列表, 块和布局代码实例
    • HTML5 网络拓扑图应用实例讲解
    • 静态资源(JS/CSS)存储在localStorage有什么缺点?为什么没有被广泛应用?

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

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