IE+JS: 上传之前检测图片文件大小October 2, 2005 at 1:34 am · Filed under Scripts
文件上传之前的检测,通常是通过文件名来判断文件类型是否合法,但是要想检测文件的大小很难办到,除非在本地或者使用控件。不过在IE下img有几个附加的属性,如:fileCreatedDate、fileModifiedDate、fileSize、fileUpdatedDate、filters,我们可以通过这些属性来获取图片文件的部分信息,如文件大小,我们用file表单同img标签结合,就能够在上传之前判断图片文件的大小是否合法了。
还有一个小小的发现就是,IE下动画的onload事件是在每次循环开始都触发,这样我们可以通过他来达到和js里setInterval()函数一样的效果,如:
这两个例子的源代码如下:第一个:
限制:<input type="text" size="4" value="10" name="fileSizeLimit" id="fileSizeLimit"/> K<input type="file" name="file1" id="file1" size="40" οnchange="changeSrc(this)"/><img src="about:blank" id="fileChecker" alt="test" height="18"/> <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 οnlοad="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; } }