js 可增加删除图片上传框js代码
js 可增加删除图片上传框js代码
本款程序可以检测用户上传图片类型,大小,在上传之前,同时也可以增加多文件上传,就是不定文件多少,仿51空间那种文件上代码
<!DOCTYPE html>
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title>图片预览效果</title>
<script src="CJL.0.1.min.js"></script>
<script src="QuickUpload.js"></script>
<script >
var ImagePreview = function (file, img, options) { this.file = $$(file); //文件对象 this.img = $$(img); //预览图片对象 this._preload = null; //预载图片对象 this._data = ""; //图像数据 this._upload = null; //remote模式使用的上传文件对象 var opt = this._setOptions(options); this.action = opt.action; this.timeout = opt.timeout; this.ratio = opt.ratio; this.maxWidth = opt.maxWidth; this.maxHeight = opt.maxHeight; this.onCheck = opt.onCheck; this.onShow = opt.onShow; this.onErr = opt.onErr; //设置数据获取程序 this._getData = this._getDataFun(opt.mode); //设置预览显示程序 this._show = opt.mode !== "filter" ? this._simpleShow : this._filterShow; }; //根据浏览器获取模式 ImagePreview.MODE = $$B.ie7 || $$B.ie8 ? "filter" : $$B.firefox ? "domfile" : $$B.opera || $$B.chrome || $$B.safari ? "remote" : "simple"; //透明图片 ImagePreview.TRANSPARENT = $$B.ie7 || $$B.ie6 ? "mhtml:" + document.scripts[document.scripts.length - 1].getAttribute("src", 4) + "!blankImage" : ""; ImagePreview.prototype = { //设置默认属性 _setOptions : function (options) { this.options = { //默认值 mode : ImagePreview.MODE, //预览模式 ratio : 0, //自定义比例 maxWidth : 0, //缩略图宽度 maxHeight : 0, //缩略图高度 onCheck : function () {}, //预览检测时执行 onShow : function () {}, //预览图片时执行 onErr : function () {}, //预览错误时执行 //以下在remote模式时有效 action : undefined, //设置action timeout : 0 //设置超时(0为不设置) }; return $$.extend(this.options, options || {}); }, //开始预览 preview : function () { if (this.file && false !== this.onCheck()) { this._preview(this._getData()); } }, //根据mode返回数据获取程序 _getDataFun : function (mode) { switch (mode) { case "filter": return this._filterData; case "domfile": return this._domfileData; case "remote": return this._remoteData; case "simple": default: return this._simpleData; } }, //滤镜数据获取程序 _filterData : function () { this.file.select(); try { return document.selection.createRange().text; } finally { document.selection.empty(); } }, //domfile数据获取程序 _domfileData : function () { return this.file.files[0].getAsDataURL(); }, //远程数据获取程序 _remoteData : function () { this._setUpload(); this._upload && this._upload.upload(); }, //一般数据获取程序 _simpleData : function () { return this.file.value; }, //设置remote模式的上传文件对象 _setUpload : function () { if (!this._upload && this.action !== undefined && typeof QuickUpload === "function") { var oThis = this; this._upload = new QuickUpload(this.file, { onReady : function () { this.action = oThis.action; this.timeout = oThis.timeout; var parameter = this.parameter; parameter.ratio = oThis.ratio; parameter.width = oThis.maxWidth; parameter.height = oThis.maxHeight; }, onFinish : function (iframe) { try { oThis._preview(iframe.contentWindow.document.body.innerHTML); } catch (e) { oThis._error("remote error"); } }, onTimeout : function () { oThis._error("timeout error"); } }); } }, //预览程序 _preview : function (data) { //空值或相同的值不执行显示 if (!!data && data !== this._data) { this._data = data; this._show(); } }, //设置一般预载图片对象 _simplePreload : function () { if (!this._preload) { var preload = this._preload = new Image(), oThis = this; preload.onload = function () { oThis._imgShow(oThis._data, this.width, this.height); }; preload.onerror = function () { oThis._error(); }; } }, //一般显示 _simpleShow : function () { this._simplePreload(); this._preload.src = this._data; }, //设置滤镜预载图片对象 _filterPreload : function () { if (!this._preload) { var preload = this._preload = document.createElement("div"); //隐藏并设置滤镜 $$D.setStyle(preload, { width : "1px", height : "1px", visibility : "hidden", position : "absolute", left : "-9999px", top : "-9999px", filter : "progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod='image')" }); //插入body var body = document.body; body.insertBefore(preload, body.childNodes[0]); } }, //滤镜显示 _filterShow : function () { this._filterPreload(); var preload = this._preload, data = this._data.replace(/[)'"%]/g, function (s) { return escape(escape(s)); }); try { preload.filters.item("DXImageTransform.Microsoft.AlphaImageLoader").src = data; } catch (e) { this._error("filter error"); return; } //设置滤镜并显示 this.img.style.filter = "progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod='scale',src=" " + data + " ")"; this._imgShow(ImagePreview.TRANSPARENT, preload.offsetWidth, preload.offsetHeight); }, //显示预览 _imgShow : function (src, width, height) { var img = this.img, style = img.style, ratio = Math.max(0, this.ratio) || Math.min(1, Math.max(0, this.maxWidth) / width || 1, Math.max(0, this.maxHeight) / height || 1); //设置预览尺寸 style.width = Math.round(width * ratio) + "px"; style.height = Math.round(height * ratio) + "px"; //设置src img.src = src; this.onShow(); }, //销毁程序 dispose : function () { //销毁上传文件对象 if (this._upload) { this._upload.dispose(); this._upload = null; } //销毁预载图片对象 if (this._preload) { var preload = this._preload, parent = preload.parentNode; this._preload = preload.onload = preload.onerror = null; parent && parent.removeChild(preload); } //销毁相关对象 this.file = this.img = null; }, //出错 _error : function (err) { this.onErr(err); } }
</script>
</head>
<body>
<style>
.perview {width:600px;background:#fff;font-size:12px; border-collapse:collapse;}
.perview td, .perview th {padding:5px;border:1px solid #ccc;}
.perview th {background-color:#f0f0f0; height:20px;}
.perview a:link, .perview a:visited, .perview a:hover, .perview a:active {color:#00F;}
.perview table{ width:100%;border-collapse:collapse;}
</style>
<table border="0" class="perview">
<tr>
<th>选择文件</th>
<th width="50%">预览图</th>
</tr>
<tr>
<td height="200"><input id="idFile" name="pic" type="file" /></td>
<td align="center"><img id="idImg" /></td>
</tr>
</tbody>
</table>
<script>
var ip = new ImagePreview( $$("idFile"), $$("idImg"), {
maxWidth: 200, maxHeight: 200, action: "ImagePreview.ashx"
});
ip.img.src = ImagePreview.TRANSPARENT;
ip.file.onchange = function(){ ip.preview(); };
</script>
<br />
<style>
/*file样式*/
#idPicFile {
width:80px;height:20px;overflow:hidden;position:relative;
background:url(http://www.cnblogs.com/images/cnblogs_com/cloudgamer/169629/o_addfile.jpg) center no-repeat;
}
#idPicFile input {
font-size:20px;cursor:pointer;
position:absolute;right:0;bottom:0;
filter:alpha(opacity=0);opacity:0;
outline:none;hide-focus:expression(this.hideFocus=true);
}
</style>
<table class="perview">
<tr>
<th align="right"> 选择图片: </th>
<td width="75%"> <div id="idPicFile"> </div> </td>
</tr>
<tr>
<td colspan="2"><table>
<thead>
<tr>
<th> 文件路径 </th>
<th width="30%"> 预览图 </th>
<th width="20%"> 操作 </th>
</tr>
</thead>
<tbody id="idPicList">
<tr>
<td></td>
<td align="center"></td>
<td align="center"><a href="#">移除</a></td>
</tr>
</tbody>
</table></td>
</tr>
</table>
<script>
var table = $$("idPicList"), model = table.removeChild(table.rows[0]);
function AddPreview() { var file = document.createElement("input"), img = document.createElement("img"), ip = new ImagePreview(file, img, { maxWidth : 150, maxHeight : 100, action : "ImagePreview.ashx", onErr : function () { alert("载入预览出错!"); ResetFile(file); }, onCheck : CheckPreview, onShow : ShowPreview }); file.type = "file"; file.name = "pic"; file.onchange = function () { ip.preview(); }; $$("idPicFile").appendChild(file); } //检测程序 var exts = "jpg|gif|bmp", paths = "|"; function CheckPreview() { var value = this.file.value, check = true; if (!value) { check = false; alert("请先选择文件!"); } else if (!RegExp(".(?:" + exts + ")$$", "i").test(value)) { check = false; alert("只能上传以下类型:" + exts); } else if (paths.indexOf("|" + value + "|") >= 0) { check = false; alert("已经有相同文件!"); } check || ResetFile(this.file); return check; } //显示预览 function ShowPreview() { var row = table.appendChild(model.cloneNode(true)), file = this.file, value = file.value, oThis = this; row.appendChild(file).style.display = "none"; row.cells[0].innerHTML = value; row.cells[1].appendChild(this.img); row.getElementsByTagName("a")[0].onclick = function () { oThis.dispose(); table.removeChild(row); paths = paths.replace(value, ""); return false; }; paths += value + "|"; AddPreview(); } AddPreview(); function ResetFile(file) { file.value = ""; //ff chrome safari if (file.value) { if ($$B.ie) { //ie with (file.parentNode.insertBefore(document.createElement('form'), file)) { appendChild(file); reset(); removeNode(false); } } else { //opera file.type = "text"; file.type = "file"; } } }
</script>
</body>
</html>
文章链接:http://www.phprm.com/code/5a436baeb4b84586106bcd64a33c1855.html
随便收藏,请保留本文地址!