IE+JS: 上传之前检测图片文件大小及类型

文件上传之前的检测,通常是通过文件名来判断文件类型是否合法,但是要想检测文件的大小很难办到,除非在本地或者使用控件。不过在IE下img有几个附加的属性,如:fileCreatedDate、fileModifiedDate、fileSize、fileUpdatedDate、filters,我们可以通过这些属性来获取图片文件的部分信息,如文件大小,我们用file表单同img标签结合,就能够在上传之前判断图片文件的大小是否合法了。

还有一个小小的发现就是,IE下动画的onload事件是在每次循环开始都触发,这样我们可以通过他来达到和js里setInterval()函数一样的效果,如:


这两个例子的源代码如下:
第一个:

限制:
html
<input type="text" size="4" value="10" name="fileSizeLimit" id="fileSizeLimit"/> K
<input type="file" name="file1" id="file1" size="40" onchange="changeSrc(this)"/>
<img src="about:blank" id="fileChecker" alt="test" height="18"/>


js
<script type="text/javascript">
var oFileChecker = document.getElementById("fileChecker");

function changeSrc(filePicker)
{
oFileChecker.src = filePicker.value;
}

oFileChecker.onreadystatechange = function ()
{
if (oFileChecker.readyState == "complete")
{
checkSize();
}
}

function checkSize()
{
var limit = document.getElementById("fileSizeLimit").value * 1024;

if (oFileChecker.fileSize > limit)
{
alert("too large");
}
else
{
alert("ok");
}
}
</script>


第二个:


<img src="monkey.gif" id="monkey" alt="monkey" /> loops: <span id="loopsNum"></span>

<script type="text/javascript">
var loops = 0;
document.getElementById("monkey").onload = function ()
{
document.getElementById("loopsNum").innerText= loops;
loops ++;
}
</script>



每三个:

<script>
function checkSize(imgObj)
{
alert(imgObj.fileSize);
}

</script>
<BODY>
<form id="aform">
<img id=im onload="checkSize(this)" src="http://www.google.com/logos/winter_holiday05_5res.gif">
</form>
</BODY>



限制文件类型

function CheckFile(){
with(document.aform){
var filepath1 =SourceFile1.value;
var fileextend1 = filepath1.substring(filepath1.lastIndexOf('.')+1,filepath1.length);
if(fileextend1==""){
alert("对不起,你必须选择一个文件!");
return false;
}
fileextend1 = fileextend1.toLowerCase();
if(fileextend1 != "xls" && fileextend1 !="txt"){
alert("对不起,您选择的文件格式不对,请选择文本文件(txt)或Excel文件。");
return false;
}
if(fileextend1 == "xls"){
if(!confirm("上传EXCEL文件速度将会很慢,我们推荐您使用文本格式。你确定要使用这个文件吗?")){
return false;
}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值