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 相关文章推荐
JavaScript 开发中规范性的一点感想
Jun 23 Javascript
js 字符串操作函数
Jul 25 Javascript
JQuery做的一个简单的点灯游戏分享
Jul 16 Javascript
JS+CSS实现Div弹出窗口同时背景变暗的方法
Mar 04 Javascript
angularjs 表单密码验证自定义指令实现代码
Oct 27 Javascript
js中less常用的方法小结
Aug 09 Javascript
在 Vue 项目中引入 tinymce 富文本编辑器的完整代码
May 04 Javascript
Angularjs实现多图片上传预览功能
Jul 18 Javascript
微信小程序如何访问公众号文章
Jul 08 Javascript
layer弹窗在键盘按回车将反复刷新的实现方法
Sep 25 Javascript
vue-resource:jsonp请求百度搜索的接口示例
Nov 09 Javascript
webpack+express实现文件精确缓存的示例代码
Jun 11 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
从零开始学YII2框架(一)通过Composer安装Yii2框架
2014/08/20 PHP
php实现按指定大小等比缩放生成上传图片缩略图的方法
2014/12/15 PHP
PHP PDO操作MySQL基础教程
2017/06/05 PHP
PHP检测一个数组有没有定义的方法步骤
2019/07/20 PHP
Js注册协议倒计时的小例子
2013/06/24 Javascript
js AppendChild与insertBefore用法详细对比
2013/12/16 Javascript
js操作输入框提示信息且响应鼠标事件
2014/03/25 Javascript
JavaScript对数组进行随机重排的方法
2015/07/22 Javascript
JS脚本根据手机浏览器类型跳转WAP手机网站(两种方式)
2015/08/04 Javascript
Bootstrap的图片轮播示例代码
2015/08/31 Javascript
jquery插件jquery.LightBox.js实现点击放大图片并左右点击切换效果(附demo源码下载)
2016/02/25 Javascript
微信小程序 scroll-view隐藏滚动条详解
2017/01/16 Javascript
浅谈JavaScript正则表达式-非捕获性分组
2017/03/08 Javascript
JavaScript中在光标处插入添加文本标签节点的详细方法
2017/03/22 Javascript
从对象列表中获取一个对象的方法,依据关键字和值
2017/09/20 Javascript
node错误处理与日志记录的实现
2018/12/24 Javascript
ES10 特性的完整指南小结
2019/03/04 Javascript
原生js实现拖拽移动与缩放效果
2020/08/24 Javascript
python中numpy包使用教程之数组和相关操作详解
2017/07/30 Python
利用Python如何将数据写到CSV文件中
2018/06/05 Python
python实现一组典型数据格式转换
2018/12/15 Python
Python logging设置和logger解析
2019/08/28 Python
css3模拟jq点击事件的实例代码
2017/07/06 HTML / CSS
Anthropologie英国:美国家喻户晓的休闲服装和家居产品品牌
2018/12/05 全球购物
Burt’s Bees英国官网:世界领先的天然个人护理品牌
2020/08/17 全球购物
实习生个人找工作的自我评价
2013/10/30 职场文书
工程总经理工作职责
2013/12/09 职场文书
汇源肾宝广告词
2014/03/20 职场文书
学生会主席竞聘书
2014/03/31 职场文书
HR求职自荐信范文
2014/06/21 职场文书
大学毕业生推荐信
2014/07/09 职场文书
2015元旦感言
2015/12/09 职场文书
基于Redis过期事件实现订单超时取消
2021/05/08 Redis
微信小程序基础教程之echart的使用
2021/06/01 Javascript
Dubbo+zookeeper搭配分布式服务的过程详解
2022/04/03 Java/Android
什么是clearfix (一文搞清楚css清除浮动clearfix)
2023/05/21 HTML / CSS