javascript实现的图片预览和上传功能示例【兼容IE 9】


Posted in Javascript onMay 01, 2020

本文实例讲述了javascript实现的图片预览和上传功能。分享给大家供大家参考,具体如下:

下载DEMO:https://github.com/CaptainLiao/zujian/tree/master/Upload

对于现代浏览器来说,要实现图片预览非常简单:

1、fileReader.readAsDataURL(file)

2、window.URL.createObjectURL(file)

以上两种方法分别可以得到一个base64和一个blob对象的URL地址,从而实现预览。但是,他们只支持在IE10+,显然这是不够的,如何实现低版本IE浏览器的图片预览呢?代码如下:

<html xmlns="http://www.w3.org/1999/xhtml">
 <head>
 <script type="text/javascript" language="javascript">
    $('#preview_fake').change(function () {
      previewImg($(this), $('#preview'));

    });
    function previewImg($inputId, $previewId) {
      var inputId = $inputId[0],
        previewId = $previewId[0];
      $previewId.empty();
      if(/msie/.test(navigator.userAgent.toLowerCase())){
        if($.support.version == 6.0){
          $previewId.attr("src",inputId.value);
        }else{
          inputId.select();
          var reallocalpath = document.selection.createRange().text;
          previewId.style.filter = "progid:DXImageTransform.Microsoft.AlphaImageLoader(enabled=true, sizingMethod='scale',src=\"" + reallocalpath + "\")";
          // 设置img的src为base64编码的透明图片 取消显示浏览器默认图片
          previewId.src = 'data:image/gif;base64,R0lGODlhAQABAIAAAP///wAAACH5BAEAAAAALAAAAAABAAEAAAICRAEAOw==';
        }
      }else {
        $previewId.attr("src",window.URL.createObjectURL(previewFake.files[0]));
      }
    }
 </script>

 </head>
 <body>
   <form id="form1" runat="server">
   <div>
     选择图片:<input type="file" size="20" id='preview_fake'" /> 
   </div>
    <div id="preview" style="width: 300px; height: 300px">
   </div>    
   </form>
 </body>
</html>

这样,我们就能够在IE10- 下预览上传的图片了。

在这里,有必要对几个参数说明一下,以免后人再入坑!

progid:DXImageTransform.Microsoft.AlphaImageLoader([enabled=bEnabled ,] [sizingMethod=sSize ,] src=sURL)

enabled: 可选。布尔值(Boolean)。设置或检索滤镜是否激活。

  • true:默认值。滤镜激活。
  • false:滤镜被禁止。

sizingMethod:可选。字符串(String)。设置或检索滤镜作用的对象的图片在对象容器边界内的显示方式。

  • crop:剪切图片以适应对象尺寸。
  • image:默认值。增大或减小对象的尺寸边界以适应图片的尺寸。
  • scale:缩放图片以适应对象的尺寸边界。

src: 必选项。字符串(String)。使用绝对或相对 url 地址指定背景图像。假如忽略此参数,滤镜将不会作用。

以上,可以实现低版本IE浏览器的图片预览,但要上传到服务器还需要一番周折。对于单张图片,可以通过<form>表单提交,但对于多张图片,这需要flash技术的支持,实现起来相当麻烦。

这里,楼主推荐一个现有的轮子:webuploader 组件。

希望本文所述对大家JavaScript程序设计有所帮助。

Javascript 相关文章推荐
使用jquery实现div的tab切换实例代码
May 27 Javascript
JQuery表格内容过滤的实现方法
Jul 05 Javascript
javascript动态向网页中添加表格实现代码
Feb 19 Javascript
jQuery实现字符串按指定长度加入特定内容的方法
Mar 11 Javascript
总结十个Angular.js由浅入深的面试问题
Aug 26 Javascript
JS 在数组指定位置插入/删除数据的方法
Jan 12 Javascript
javascript 中事件冒泡和事件捕获机制的详解
Sep 01 Javascript
从对象列表中获取一个对象的方法,依据关键字和值
Sep 20 Javascript
Vue+Vux项目实践完整代码
Nov 30 Javascript
利用ECharts.js画K线图的方法示例
Jan 10 Javascript
Vue打包后出现一些map文件的解决方法
Feb 13 Javascript
浅谈js中的attributes和Attribute的用法与区别
Jul 16 Javascript
jQuery实现的移动端图片缩放功能组件示例
May 01 #jQuery
jQuery实现移动端图片上传预览组件的方法分析
May 01 #jQuery
jQuery实现的上拉刷新功能组件示例
May 01 #jQuery
JS深入学习之数组对象排序操作示例
May 01 #Javascript
vue 输入电话号码自动按3-4-4分割功能的实现代码
Apr 30 #Javascript
浅谈Vue3.0新版API之composition-api入坑指南
Apr 30 #Javascript
JavaScript变量Dom对象的所有属性
Apr 30 #Javascript
You might like
PH P5.2至5.5、5.6的新增功能详解
2014/07/14 PHP
php实现二进制和文本相互转换的方法
2015/04/18 PHP
PHP正则匹配到2个字符串之间的内容方法
2018/12/24 PHP
怎么让脚本或里面的函数在所有图片都载入完毕的时候执行
2006/10/17 Javascript
javascript 打印页面代码
2009/03/24 Javascript
CutePsWheel javascript libary 控制输入文本框为可使用滚轮控制的js库
2010/02/07 Javascript
JS继承--原型链继承和类式继承
2013/04/08 Javascript
根据选择不同的下拉值出现相对应的文本输入框
2013/08/01 Javascript
node.js中的fs.close方法使用说明
2014/12/17 Javascript
jQuery中unbind()方法用法实例
2015/01/19 Javascript
Nodejs学习笔记之入门篇
2015/04/16 NodeJs
ztree获取选中节点时不能进入可视区域出现BUG如何解决
2015/12/03 Javascript
完美解决JS文件页面加载时的阻塞问题
2016/12/18 Javascript
详解vue前后台数据交互vue-resource文档
2017/07/19 Javascript
JavaScript实现数值自动增加动画
2017/12/28 Javascript
Node.js成为Web应用开发最佳选择的原因
2018/02/05 Javascript
Node.js 使用AngularJS的方法示例
2018/05/11 Javascript
Vue 嵌套路由使用总结(推荐)
2020/01/13 Javascript
vue使用Sass时报错问题的解决方法
2020/10/14 Javascript
Python通过90行代码搭建一个音乐搜索工具
2015/07/29 Python
Python爬虫实现验证码登录代码实例
2019/05/10 Python
python实现二级登陆菜单及安装过程
2019/06/21 Python
python-序列解包(对可迭代元素的快速取值方法)
2019/08/24 Python
基于virtualenv创建python虚拟环境过程图解
2020/03/30 Python
Python3基于plotly模块保存图片表格
2020/08/03 Python
Original Penguin美国官网:布拉德皮特、强尼德普喜爱的服装品牌
2016/10/25 全球购物
Java语言程序设计测试题判断题部分
2013/01/06 面试题
留学自荐信
2013/10/10 职场文书
自荐书模板
2013/12/19 职场文书
互联网创业计划书写作技巧攻略
2014/03/23 职场文书
四风批评与自我批评范文
2014/10/14 职场文书
2014年乡镇党建工作总结
2014/11/11 职场文书
大学毕业论文致谢词
2015/05/14 职场文书
幼儿园园长工作总结2015
2015/05/25 职场文书
小学2016年“我们的节日·重阳节”活动总结
2016/04/01 职场文书
python 爬取豆瓣网页的示例
2021/04/13 Python