微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

基于JQuery实现图片上传预览与删除操作

本文实例为大家分享了JQuery实现图片上传预览与删除的具体代码,经测试目前满足谷歌、火狐、360、IE6,7,8,9,10,11等浏览器,供大家参考,具体内容如下

1. preview.2.0.html

rush:xhtml;"> <a href="https://www.jb51.cc/tag/shangchuan/" target="_blank" class="keywords">上传</a><a href="https://www.jb51.cc/tag/tupian/" target="_blank" class="keywords">图片</a>预览 <Meta http-equiv="content-type" content="text/html; charset=UTF-8">

2. srdz.preview.2.0.css

rush:css;"> .btn-pic { display: block; position: relative; width: 120px; height: 40px; overflow: hidden; cursor: pointer; text-align: center; }

.btn-pic-bg {
border: 1px solid #ff9000;
background: none repeat scroll 0 0 #ff9000;
color: #ffffff;
text-decoration: none;
}

.btn-pic span {
display: block;
line-height: 39px;
}

.ipt-bg {
display: block;
position: absolute;
top: 0;
left: 0;
width: 120px;
height: 40px;
font-size: 100px;
opacity: 0;
filter: alpha(opacity=0);
}

.spanc{
color: red;
}

.drt {
float: right;
display: none;
}

.dft {
float: left;
}

3. srdz.preview.2.0.js

rush:js;"> function ImgPreview(){}

ImgPreview.prototype.preview=function(options){

var time = new Date().getTime();
var fileid = "file" + time;
var xdelid = "xdel" + time;
var delid = "del" + time;
var viewid = "view" + time;

var htm = "" +
"

" +
"
";

$("#" + options.previewid).html(htm);

$("#" + fileid).bind("click",function(){

var $this =$(this);

var browser={
isIE:function(ver){
var b = document.createElement('b');
b.innerHTML = '';
return b.getElementsByTagName('i').length === 1;
}
};

$this.change(function(){
var regex=/(.*).(jpg|jpeg|png)$/;
var val = $this.val();
if(!regex.test(val)){
$("#" + viewid).html("请选择正确的图片(jpg、jpeg、png)!");
return;
}

if(browser.isIE(6)){
HanderOther($this);
}else if(browser.isIE(7) || browser.isIE(8) || browser.isIE(9)){
HanderIE789($this);
}else if(window.FileReader){
HanderFileReader($this);
}else{
$("#" + viewid).html("该浏览器不支持预览图片!");
}

function HanderFileReader($this){
var oFReader = new window.FileReader(),rFilter = /^(?:image\/bmp|image\/cis-cod|image\/gif|image\/ief|image\/jpeg|image\/jpeg|image\/jpeg|image\/pipeg|image\/png|image\/svg+xml|image\/tiff|image\/x-cmu-raster|image\/x-cmx|image\/x-icon|image\/x-portable-anymap|image\/x-portable-bitmap|image\/x-portable-graymap|image\/x-portable-pixmap|image\/x-rgb|image\/x-xbitmap|image\/x-xpixmap|image\/x-xwindowdump)$/i;
oFReader.onload = function (oFREvent){
$("#" + viewid).html("");
$("#" + xdelid).show();
};

var aFiles = $this.get(0).files;
if (aFiles.length == 0) { return; }
if (!rFilter.test(aFiles[0].type)) { 
 $("#" + viewid).html("<span class='spanc'>请选择正确的<a href="https://www.jb51.cc/tag/tupian/" target="_blank" class="keywords">图片</a>(jpg、jpeg、png)!</span>"); 
 return; 
}
oFReader.readAsDataURL(aFiles[0]);

}

function HanderIE789($this){
if(options.width != null && parseInt(options.width) > 0){
$("#" + viewid).css("width",options.width + "px");
}else{
$("#" + viewid).css("width","378px");
}
if(options.height != null && parseInt(options.height) > 0){
$("#" + viewid).css("height",options.height + "px");
}else{
$("#" + viewid).css("height","358px");
}
$("#" + viewid).css("filter","progid:DXImageTransform.Microsoft.AlphaimageLoader(sizingMethod=scale,src='"+GetImgSrc($this)+"')");
$("#" + xdelid).show();
}

function HanderOther($this){
$("#" + viewid).html("");
$("#" + xdelid).show();
}

function GetImgSrc($this){
$this.select();
$this.blur();
var imgSrc =document.selection.createrange().text;
document.selection.empty();
return imgSrc;
}

});
});//绑定按钮事件

$("#" + delid).bind("click",function(){
var browser={
isIE:function(ver){
var b = document.createElement('b');
b.innerHTML = '';
return b.getElementsByTagName('i').length === 1;
}
};

if(browser.isIE(7) || browser.isIE(8) || browser.isIE(9)){
$("#" + fileid).val('');
$("#" + viewid).css("filter","");
$("#" + viewid).css("width","");
$("#" + viewid).css("height","");
$("#" + xdelid).hide();
}else{
$("#" + fileid).val('');
$("#" + viewid).empty();
$("#" + xdelid).hide();
}
});
};

4. jquery.min.js

更多精彩内容,请点击上传操作汇总》,进行深入学习和研究。

以上就是本文的全部内容,希望对大家学习jquery程序设计有所帮助。

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐