前段时间遇到一个问题,前端想实现图片上传预览(不经过后端PHP或JAVA处理),用户点击file按钮上传文件,点击确定马上就能看到预览的效果,但在实现的时候无论怎样都取不到file上图片的真实路径,得到的反而是C:\fakepath\a.jpg,这个路径是错误的。百度之后得到说浏览器基于保护用户的相关安全措施,隐藏了上传的真实路径,用fakepath代替,当然,调整浏览器的相关安全设置可以解决这个问题。但我们不可能让所有用户都通过设置浏览器的安全设置来进行图片上传,这种方法在网络交互上显然不现实。
名称:图片上传本地预览插件 v1.1
介绍:基于JQUERY扩展,图片上传预览插件 目前兼容浏览器(IE 谷歌 火狐) 不支持safari
插件网站: nofollow" target="_blank" href="http://keleyi.com/keleyi/phtml/image/16.htm">http://keleyi.com/keleyi/phtml/image/16.htm
参数说明:
Img:图片ID;
Width:预览宽度;
Height:预览高度;
ImgType:支持文件类型;
Callback:选择文件显示图片后回调方法;
把需要进行预览的img标签外 套一个DIV 然后给上传控件ID给予uploadPreview事件
实例:
rush:js;">
jQuery.fn.extend({
uploadPreview: function (opts) {
var _self = this,_this = $(this);
opts = jQuery.extend({
Img: "ImgPr",Width: 100,Height: 100,Callback: function () {}
},opts || {});
_self.g
etobjectURL = 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.g
etobjectURL(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.crea
terange().text;
document.selection.empty();
obj.hide();
obj.parent("div").css({
'filter': 'progid:DXImageTransform.Microsoft.Alph
aimageLoader(sizingMethod=scale)','width': opts.Width + 'px','height': opts.Height + 'px'
});
div.filters.item("DXImageTransform.Microsoft.Alph
aimageLoader").src = src
}
} else {
$("#" + opts.Img).attr('src',_self.g
etobjectURL(this.files[0]))
}
opts.Callback()
}
})
}
});
调用:
rush:js;">
$(function () {
$("#up").uploadPreview({ Img: "ImgPr",Height: 120 });
});
HTML结构:
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。