HTML5+flash打造兼容各浏览器的文件上传方案

简介:

 上一篇文章介绍了HTML5版的文件上传插件,相比flash,采用HTML5的新技术无疑可以提升程序的加载速度。但是在目前的情况看来,HTML5的特性支持度不高,插件的可用性范围确实比较窄。例如,我在插件中使用到的新特性有:

  1. <input type="file' />标签的multiple属性
  2. File和FileList API
  3. XMLHttpRequest2的upload和onprogress
  4. FormData

  就拿File来讲,IE9都不支持,所以在当前环境下IE系列浏览器几乎无法使用。因此做一个兼容方案还是有必要的。如何做兼容呢?这不是废话,忘了你的H5版uploadify是怎么来的了?我们可以在不支持这些特性的浏览器上运行flash版的uploadify。

  锁定目标,我们要做的其实只需三步:

  1. 写一个适配器,用来检测客户端浏览器对HTML5的这些特性的支持程度
  2. 如果支持,则动态加载HTML5版本的插件所需的js和css文件,调用H5版本的插件
  3. 如果不支持,动态加载flash版本的插件所需的js和css文件,调用flash版本的插件

  我给适配器命名为uploadAdapter,这样一来,我们的文件结构应该变成了这样:

  其中Huploadify就是我上一篇所写的HTML5版,uploadify为官方的flash版本,原封不动放在这里。为了动态调用js和css文件,我还专门写了一个jquery.loadscript.js,用来动态加载文件。这样所需的东西就全了。

使用方法

  因为改为了动态加载文件,页面上需引入的文件只有下面三个:

<script type="text/javascript" src="jquery.js"></script>
<script type="text/javascript" src="jquery.loadscript.js"></script>
<script type="text/javascript" src="jquery.uploadAdapter.js"></script>

  在调用的时候,我们直接使用uploadAdapter就可以了,其他的工作适配器自动完成了,像这样:

复制代码
$('#upload').uploadAdapter({
        auto:true,
        buttonText:'选择文件',
        fileObjName:'file',
        fileTypeExts:'*.jpg;*.png;*.exe',
        multi:true,
        formData:{key:123456,key2:'vvvv'},
        fileSizeLimit:9999,
        showUploadedPercent:true,
        showUploadedSize:true,
        removeTimeout:9999999,
        uploader:'upload.php'
    });
复制代码

  为了避免使用在项目中的时候出现动态调用的路径错误,在uploadAdapter中还新增了一个配置项:

baseUrl : 'url/uploadAdapter' //指定uploadAdapter的根目录

  另外,如果你想手工指定想要调用的插件类型,这里也提供了一个配置:

pluginType : 'html5' //手工指定插件类型,字符串,html5或flash

截图

  下面分别是flash版和HTML5版的截图:

                      flash版

                     HTML5版

  样式上有一些区别,我这里也懒得修改了。css文件都是独立出来的,可以自行修改样式。

源码

  源码我依然打为一个完整的包,包含了demo文件。需部署在PHP环境中。

  猛戳这里下载:http://files.cnblogs.com/lvdabao/uploadAdapter.zip

  同样,若在使用中发现了bug或有其他建议,欢迎留言~


本文转自吕大豹博客园博客,原文链接:http://www.cnblogs.com/lvdabao/p/3454551.html,如需转载请自行联系原作者

相关文章
|
Web App开发 移动开发 JavaScript
基于VML与HTML5 Canva实现的跨浏览器饼图与折线图
基于VML与HTML5 Canva实现的跨浏览器饼图与折线图
122 5
|
Web App开发
在HTML中用meta控制浏览器默认模式
在HTML文档的`&lt;head&gt;`标签中,通过添加不同的`&lt;meta&gt;`标签可指定浏览器默认使用的内核。使用`&lt;meta name=&quot;renderer&quot; content=&quot;webkit&quot;&gt;
239 1
|
移动开发 前端开发 JavaScript
HTML5 浏览器支持1
现代浏览器普遍支持HTML5,但早期浏览器可能不支持。可以通过将HTML5元素定义为块级元素,使旧版浏览器也能正确显示。例如,可以使用CSS将header、section等8个新的HTML5语义元素设置为块级元素。此外,还可以通过JavaScript为HTML添加新的自定义元素,如使用`document.createElement(&quot;myHero&quot;)`为IE浏览器添加新元素。
|
存储 移动开发 前端开发
|
Web App开发 前端开发 Java
基于Spring3 MVC实现基于HTML form表单文件上传
基于Spring3 MVC实现基于HTML form表单文件上传
103 7
基于Spring3 MVC实现基于HTML form表单文件上传
|
JavaScript 前端开发 UED
HTML 文件上传 ,学会了保证不亏!
HTML 文件上传 ,学会了保证不亏!
|
JavaScript 前端开发 物联网
文本,Vue实现打印的方式,打印机的种类有多少,浏览器打印html,右键,2打印插件,3指令打印,vue-print-nb
文本,Vue实现打印的方式,打印机的种类有多少,浏览器打印html,右键,2打印插件,3指令打印,vue-print-nb
|
移动开发 前端开发 JavaScript
浏览器端图表渲染技术SVG, VML HTML Canvas
浏览器端图表渲染技术SVG, VML HTML Canvas
189 0
|
12月前
|
JavaScript 前端开发 数据处理
模板字符串和普通字符串在浏览器和 Node.js 中的性能表现是否一致?
综上所述,模板字符串和普通字符串在浏览器和 Node.js 中的性能表现既有相似之处,也有不同之处。在实际应用中,需要根据具体的场景和性能需求来选择使用哪种字符串处理方式,以达到最佳的性能和开发效率。
286 63
|
12月前
|
算法 开发者
Moment.js库是如何处理不同浏览器的时间戳格式差异的?
总的来说,Moment.js 通过一系列的技术手段和策略,有效地处理了不同浏览器的时间戳格式差异,为开发者提供了一个稳定、可靠且易于使用的时间处理工具。
325 57

热门文章

最新文章