这个并不是那么简单做出来的,一般情况下会加一段iframe代码,模拟ajax上传。
代码很简单,如下:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/htmlcharset=utf-8" />
<title>By:DragonDean</title>
<script type="text/javascript">
//下面用于图片上传预览功能
function setImagePreview(avalue) {
var docObj=document.getElementById("doc")
var imgObjPreview=document.getElementById("preview")
if(docObj.files &&docObj.files[0])
{
//火狐下,直接设img属性
imgObjPreview.style.display = 'block'
imgObjPreview.style.width = '150px'
imgObjPreview.style.height = '180px'
//imgObjPreview.src = docObj.files[0].getAsDataURL()
//火狐7以上版本不能用上面的getAsDataURL()方式获取,需要一下方式
imgObjPreview.src = window.URL.createObjectURL(docObj.files[0])
}
else
{
//IE下,使用滤镜
docObj.select()
var imgSrc = document.selection.createRange().text
var localImagId = document.getElementById("localImag")
//必须设置初始大小
localImagId.style.width = "150px"
localImagId.style.height = "180px"
//图片异常的捕捉,防止用户修改后缀来伪造图片
try{
localImagId.style.filter="progid:DXImageTransform.Microsoft.AlphaImageLoader(sizingMethod=scale)"
localImagId.filters.item("DXImageTransform.Microsoft.AlphaImageLoader").src = imgSrc
}
catch(e)
{
alert("您上传的图片格式不正确,请重新选择!")
return false
}
imgObjPreview.style.display = 'none'
document.selection.empty()
}
return true
}
</script>
</head>
<body>
<table width="100%" border="0" cellspacing="0" cellpadding="0">
<tbody>
<tr>
<td height="101" align="center">
<div id="localImag"><img id="preview" src="http://blog.chuangling.net/Public/images/top.jpg" width="150" height="180" style="display: blockwidth: 150pxheight: 180px"></div>
</td>
</tr>
<tr>
<td align="center" style="padding-top:10px"><input type="file" name="file"
id="doc" style="width:150px" onchange="javascript:setImagePreview()"></td>
</tr>
</tbody>
</table>
</body>
</html>
用到Jquery插件<div class="aa"></div>
<div class="bb"></div>
添加节点: $(".aa").append(".bb") 节点aa后面添加bb节点
删除节点: $(".bb").remove() 删除最后一个节点$(".bb:last").remove()
上传图片预览:
$("#flie").change(function(){ //上传 控件 上传的 预览
$("#img1").attr("src","file:///"+$("#flie").val())
})
<input id="flie" name="flie" type="file" /><br>
<img id="img1" width="500" height="200" src="">
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/htmlcharset=utf-8" />
<title>Transform</title>
<style type="text/css">
.test-box{
width:600px
margin:50px auto}
.pic{
-webkit-transition:all 1s ease-in-out
transition:all 1s ease-in-out
cursor:pointer}
.top-pic{
position:absolute
transform:scale(0,0)}
.test-box:hover .top-pic{
-webkit-transform-origin:top right
-webkit-transform:scale(1,1)}
.test-box:hover .bot-pic{
-webkit-transform:scale(0,0)
-webkit-transform-origin:bottom left
opacity: .5
-webkit-transform:rotate(120deg)
-webkit-transform-origin:bottom left
}
</style>
</head>
<body>
<div class="test-box">
<img class="pic top-pic" src="test-pic01.jpg" />
<img class="pic bot-pic" src="test-pic02.jpg" />
</div>
</body>
</html>
随便写了几个效果,没有用到JS,不过要用到JS只要把触发事件替换掉上面的hover就行了,比如:
$(".button").click(function () {
。。。
})
这里面用到CSS3,所以请不要用IE11以下的低版本浏览器,不然你啥都看不见