html input file 属性怎么能够选择之后 马上预览图片

 我来答
翻滚吧独角兽
高粉答主

2018-03-30 · 繁杂信息太多,你要学会辨别
知道大有可为答主
回答量:359
采纳率:98%
帮助的人:17.3万
展开全部

这个并不是那么简单做出来的,一般情况下会加一段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/html; charset=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: block; width: 150px; height: 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>

ningploy
2017-06-15 · TA获得超过755个赞
知道小有建树答主
回答量:717
采纳率:77%
帮助的人:483万
展开全部
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>Document</title>
</head>
<body>
<input type="file" id='file'; onchange="c()">
<img src="" id='show'>
</body>
<script type="text/javascript">
function c () {
var r= new FileReader();
f=document.getElementById('file').files[0];
r.readAsDataURL(f);
r.onload=function  (e) {
document.getElementById('show').src=this.result;
};
}
</script>
</html>

这是html5

或者用ajax上传服务器后再回传回来

js直接获取文件本地路径会产生安全问题

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
Prince____Yu
2013-12-23 · TA获得超过3718个赞
知道小有建树答主
回答量:864
采纳率:33%
帮助的人:960万
展开全部
要用ajax来做吧。需要和后台交互的。你把返回后的内容显示就好了。
追答
有问题再追问吧
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
fd1172008
2013-12-23
知道答主
回答量:71
采纳率:0%
帮助的人:16.6万
展开全部
这个并不是那么简单做出来的 一般情况下会加一段iframe代码 模拟ajax上传
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
evil瓜
2014-04-17
知道答主
回答量:6
采纳率:0%
帮助的人:7.5万
展开全部
<input type='file' id='file'/>

<script>
$(function(){
$("#file").change(function(e){
var file = e.target.files||e.dataTransfer.files;
if(file){
var reader = new FileReader();
reader.onload=function(){
$("<img src='"+this.result+"'/>").appendTo("body");

}

reader.readAsDataURL(file);
}
});
})

</script>

只要支持html5的浏览器就可以,如果没打错字的话应该应该可以运行了
本回答被提问者和网友采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
收起 更多回答(3)
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式