jquery实现图片上传前本地预览


Posted in jQuery onApril 28, 2017

前段时间遇到一个问题,前端想实现图片上传预览(不经过后端PHP或JAVA处理),用户点击file按钮上传文件,点击确定马上就能看到预览的效果,但在实现的时候无论怎样都取不到file上图片的真实路径,得到的反而是C:\fakepath\a.jpg,这个路径是错误的。百度之后得到说浏览器基于保护用户的相关安全措施,隐藏了上传的真实路径,用fakepath代替,当然,调整浏览器的相关安全设置可以解决这个问题。但我们不可能让所有用户都通过设置浏览器的安全设置来进行图片上传,这种方法在网络交互上显然不现实。

名称:图片上传本地预览插件 v1.1

介绍:基于JQUERY扩展,图片上传预览插件 目前兼容浏览器(IE 谷歌 火狐) 不支持safari

插件网站: http://keleyi.com/keleyi/phtml/image/16.htm

jquery实现图片上传前本地预览

参数说明:

Img:图片ID;

Width:预览宽度;

Height:预览高度;

ImgType:支持文件类型;

Callback:选择文件显示图片后回调方法;

使用方法:

<div>
<img id="ImgPr" width="120" height="120" /></div>
<input type="file" id="up" />

把需要进行预览的IMG标签外 套一个DIV 然后给上传控件ID给予uploadPreview事件

$("#up").uploadPreview({ Img: "ImgPr", Width: 120, Height: 120, ImgType: ["gif", "jpeg", "jpg", "bmp", "png"], Callback: function () { }});

实例:

jQuery.fn.extend({
 uploadPreview: function (opts) {
  var _self = this,
   _this = $(this);
  opts = jQuery.extend({
   Img: "ImgPr",
   Width: 100,
   Height: 100,
   ImgType: ["gif", "jpeg", "jpg", "bmp", "png"],
   Callback: function () {}
  }, opts || {});
  _self.getObjectURL = function (file) {
   var url = null;
   if (window.createObjectURL != undefined) {
    url = window.createObjectURL(file)
   } else if (window.URL != undefined) {
    url = window.URL.createObjectURL(file)
   } else if (window.webkitURL != undefined) {
    url = window.webkitURL.createObjectURL(file)
   }
   return url
  };
  _this.change(function () {
   if (this.value) {
    if (!RegExp("\.(" + opts.ImgType.join("|") + ")$", "i").test(this.value.toLowerCase())) {
     alert("选择文件错误,图片类型必须是" + opts.ImgType.join(",") + "中的一种");
     this.value = "";
     return false
    }
//高版本Jquey使用 if ($.support.leadingWhitespace)
    if ($.browser.msie) { //低版本jquery中使用的方式
     try {
      $("#" + opts.Img).attr('src', _self.getObjectURL(this.files[0]))
     } catch (e) {
      var src = "";
      var obj = $("#" + opts.Img);
      var div = obj.parent("div")[0];
      _self.select();
      if (top != self) {
       window.parent.document.body.focus()
      } else {
       _self.blur()
      }
      src = document.selection.createRange().text;
      document.selection.empty();
      obj.hide();
      obj.parent("div").css({
       'filter': 'progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod=scale)',
       'width': opts.Width + 'px',
       'height': opts.Height + 'px'
      });
      div.filters.item("DXImageTransform.Microsoft.AlphaImageLoader").src = src
     }
    } else {
     $("#" + opts.Img).attr('src', _self.getObjectURL(this.files[0]))
    }
    opts.Callback()
   }
  })
 }
});

调用:

$(function () {
 $("#up").uploadPreview({ Img: "ImgPr", Width: 120, Height: 120 });
});

HTML结构:

<div>
<img id="ImgPr" width="120" height="120" />
</div>
<input type="file" id="up" />

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

jQuery 相关文章推荐
jQuery导航条固定定位效果实例代码
May 26 jQuery
jQuery 实现双击编辑表格功能
Jun 19 jQuery
jQuery选择器_动力节点Java学院整理
Jul 05 jQuery
jQuery 实现图片的依次加载图片功能
Jul 06 jQuery
jQuery选择器之子元素选择器详解
Sep 18 jQuery
基于jquery实现五星好评
Nov 18 jQuery
jQuery实现的上传图片本地预览效果简单示例
Mar 29 jQuery
jQuery+vue.js实现的多选下拉列表功能示例
Jan 15 jQuery
AJAX在JQuery中的应用详解
Jan 30 jQuery
Jquery动态列功能完整实例
Aug 30 jQuery
JQuery基于FormData异步提交数据文件
Sep 01 jQuery
jQuery-App输入框实现实时搜索
Nov 19 jQuery
jQuery实现jQuery-form.js实现异步上传文件
Apr 28 #jQuery
jQuery tip提示插件(实例分享)
Apr 28 #jQuery
jQuery自定义元素右键点击事件(实现案例)
Apr 28 #jQuery
jQuery实现动态添加、删除按钮及input输入框的方法
Apr 27 #jQuery
jquery ui sortable拖拽后保存位置
Apr 27 #jQuery
jquery 禁止鼠标右键并监听右键事件
Apr 27 #jQuery
jQuery EasyUI tree增加搜索功能的实现方法
Apr 27 #jQuery
You might like
台湾中原大学php教程孙仲岳主讲
2008/01/07 PHP
php安全配置 如何配置使其更安全
2011/12/16 PHP
php实现读取超大文件的方法
2014/07/28 PHP
Thinkphp5.0框架使用模型Model的获取器、修改器、软删除数据操作示例
2019/10/11 PHP
PHP7 整型处理机制修改
2021/03/09 PHP
初学Javascript的一些总结
2008/11/03 Javascript
javascript 面向对象全新理练之原型继承
2009/12/03 Javascript
JavaScript Cookie的读取和写入函数
2009/12/08 Javascript
jQuery弹性滑动导航菜单实现思路及代码
2013/05/02 Javascript
js调用iframe实现打印页面内容的方法
2014/03/04 Javascript
使用text方法获取Html元素文本信息示例
2014/09/01 Javascript
JS实现仿QQ面板的手风琴效果折叠菜单代码
2015/09/11 Javascript
分享JavaScript与Java中MD5使用两个例子
2015/12/23 Javascript
vue-cli与webpack处理静态资源的方法及webpack打包的坑
2018/05/15 Javascript
[00:57]深扒TI7聊天轮盘语音出处5
2017/05/11 DOTA
[35:27]完美世界DOTA2联赛循环赛 GXR vs FTD BO2第二场 10.29
2020/10/29 DOTA
Python 查看文件的读写权限方法
2018/01/23 Python
对python requests的content和text方法的区别详解
2018/10/11 Python
解决python3运行selenium下HTMLTestRunner报错的问题
2018/12/27 Python
Python使用pandas和xlsxwriter读写xlsx文件的方法示例
2019/04/09 Python
pyqt5 使用cv2 显示图片,摄像头的实例
2019/06/27 Python
python 哈希表实现简单python字典代码实例
2019/09/27 Python
pytorch实现Tensor变量之间的转换
2020/02/17 Python
Pytorch转keras的有效方法,以FlowNet为例讲解
2020/05/26 Python
Opencv python 图片生成视频的方法示例
2020/11/18 Python
终端业务员岗位职责
2013/11/27 职场文书
员工工作表扬信范文
2014/01/13 职场文书
2014保险公司个人工作总结
2014/12/09 职场文书
2015廉洁自律个人总结
2015/02/14 职场文书
为自己工作观后感
2015/06/11 职场文书
党组织关系的介绍信模板
2019/06/21 职场文书
SQL 窗口函数实现高效分页查询的案例分析
2021/05/21 SQL Server
5行Python代码实现一键批量扣图
2021/06/29 Python
Python 阶乘详解
2021/10/05 Python
Java基础——Map集合
2022/04/01 Java/Android
Tomcat执行startup.bat出现闪退的原因及解决办法
2022/04/20 Servers