zoukankan      html  css  js  c++  java
  • HTML5+flash打造兼容各浏览器的文件上传方案

    本文来自:http://www.cnblogs.com/lvdabao/p/3454551.html;    待测试!!!

    上一篇文章介绍了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或有其他建议,欢迎留言~

  • 相关阅读:
    解决 搭建Jekins过程中 启动Tomcat的java.net.UnknownHostException异常
    射手和农场主
    java 和 JS(javaScript)中的反斜杠正则转义
    分享修改密码的SharePoint Web part: ITaCS Change Password web part
    分享微软官方Demo用的SharePoint 2010, Exchange 2010, Lync 2010虚拟机
    Office 365 的公共网站的一些限制及解决的办法
    SharePoint 2013 关闭 customErrors
    安装 KB2844286 导致SharePoint 2010 XSLT web part 显示出现错误
    安装Office Web Apps Server 2013 – KB2592525安装失败
    如何将hyper-v虚拟机转换成vmware的虚拟机- 转换SharePoint 2010 Information Worker Demonstration and Evaluation Virtual Machine (SP1)
  • 原文地址:https://www.cnblogs.com/zhou195/p/7515167.html
Copyright © 2011-2022 走看看