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 相关文章推荐
Spring shiro + bootstrap + jquery.validate 实现登录、注册功能
Jun 02 jQuery
文本溢出插件jquery.dotdotdot.js使用方法详解
Jun 22 jQuery
jQuery EasyUI开发技巧总结
Sep 26 jQuery
使用JQuery实现图片轮播效果的实例(推荐)
Oct 24 jQuery
jQuery+SpringMVC中的复选框选择与传值实例
Jan 08 jQuery
通过jquery toggleClass()属性制作文章段落更改背景颜色
May 21 jQuery
JQuery Ajax动态加载Table数据的实例讲解
Aug 09 jQuery
jquery拖拽自动排序插件使用方法详解
Jul 20 jQuery
jQuery判断自定义属性data-val用法示例
Jan 07 jQuery
jQuery操作attr、prop、val()/text()/html()、class属性
May 23 jQuery
jquery图片预览插件实现方法详解
Jul 18 jQuery
jQuery实现简易聊天框
Feb 08 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
Cakephp 执行主要流程
2010/03/24 PHP
完美解决PHP中的Cannot modify header information 问题
2013/08/12 PHP
php+mysql实现无限级分类
2015/11/11 PHP
PHP中使用foreach()遍历二维数组的简单实例
2016/06/13 PHP
thinkPHP5.0框架命名空间详解
2017/03/18 PHP
javascript 判断中文字符长度的函数代码
2012/08/27 Javascript
jCallout 轻松实现气泡提示功能
2013/09/22 Javascript
浅谈Javascript 执行顺序
2013/12/18 Javascript
js 通过html()及text()方法获取并设置p标签的显示值
2014/05/14 Javascript
Nodejs极简入门教程(二):定时器
2014/10/25 NodeJs
JS+CSS实现实用的单击输入框弹出选择框的方法
2015/02/28 Javascript
js实现横向伸展开的二级导航菜单代码
2015/08/28 Javascript
浅谈javascript 函数表达式和函数声明的区别
2016/01/05 Javascript
微信小程序 免费SSL证书https、TLS版本问题的解决办法
2016/12/14 Javascript
ajax图片上传,图片异步上传,更新实例
2016/12/30 Javascript
js实现省市级联效果分享
2017/08/10 Javascript
bootstrap table实现点击翻页功能 可记录上下页选中的行
2017/09/28 Javascript
详解Vue如何支持JSX语法
2017/11/10 Javascript
微信小程序云开发使用方法新手初体验
2019/05/16 Javascript
用Vue.js方法创建模板并使用多个模板合成
2019/06/28 Javascript
详解vue中v-bind:style效果的自定义指令
2020/01/21 Javascript
js实现自定义右键菜单
2020/05/18 Javascript
Vue+Spring Boot简单用户登录(附Demo)
2020/11/12 Javascript
jquery实现拖拽添加元素功能
2020/12/01 jQuery
深入浅析Python 中的sklearn模型选择
2019/10/12 Python
Pytorch转tflite方式
2020/05/25 Python
深入了解Python enumerate和zip
2020/07/16 Python
获取CSDN文章内容并转换为markdown文本的python
2020/09/06 Python
Python 高效编程技巧分享
2020/09/10 Python
PacSun官网:加州生活方式服装、鞋子和配饰
2018/03/10 全球购物
params有什么用
2016/03/01 面试题
运输服务质量承诺书
2014/03/27 职场文书
个人合伙协议书范本
2014/10/14 职场文书
情感电台广播稿
2015/08/18 职场文书
2016新党章学习心得体会
2016/01/15 职场文书
如何使用 resize 实现图片切换预览功能
2021/08/23 HTML / CSS