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

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

限制: K test

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

monkey  loops:


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

限制:<input type="text" size="4" value="10" name="fileSizeLimit" id="fileSizeLimit"/> 
<input type="file" name="file1" id="file1" size="40" onchange="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").innerTextloops;
    
loops ++;
}
</script> 

另外补充一些手册里的东西:
<input type="hidden" name="MAX_FILE_SIZE" value="30000" />
MAX_FILE_SIZE 隐藏字段(单位为字节)必须先于文件输入字段,其值为接收文件的最大尺寸。这是对浏览器的一个建议,PHP 也会检查此项。在浏览器端可以简单绕过此设置,因此不要指望用此特性来阻挡大文件。实际上,PHP 设置中的上传文件最大值是不会失效的。但是最好还是在表单中加上此项目,因为它可以避免用户在花时间等待上传大文件之后才发现文件过大上传失败的麻烦。

注意:本文所讨论的特性仅在IE下有效。

原创文章,转载请注明出处

13 Comments »

  1. Dakkon said,

    October 7, 2005 @ 2:11 am

    发现似乎在ie下浏览后面是个方块,换了firefox可以看到test字样

  2. legend said,

    October 7, 2005 @ 5:12 am

    因为刚开始指定的图片地址是:about:blank,所以是红叉,缩小了所以看起来跟方块似的。firefox下默认的安全设定,没法引用本地图片文件,所以显示不出图片来,就显示了这个图片的alt属性”test”。这些可以用css隐藏掉。

  3. styleku said,

    December 16, 2005 @ 12:19 am

    在Firefox下没法使用。

  4. thw said,

    December 23, 2005 @ 8:15 pm

    站长,你好,这个代码好极了!可是我还想问一下,比如这样的
    [quote]名称 地址LOGO:
    [/quote]我的意思是说能不能在写入图片地址时就可以检查大小呢?谢谢啊!!

  5. thw said,

    December 23, 2005 @ 8:17 pm

    不好意思,有些内容没显示出来
    名称 地址LOGO:
    我的意思是说能不能在写入图片地址时就可以检查大小呢?谢谢啊!!

  6. thw said,

    December 23, 2005 @ 8:20 pm

    我的意思是说能不能在写入图片地址时就是在文本框输入图片地址时就可以检查大小呢?

  7. 刘 said,

    January 22, 2006 @ 1:10 am

  8. rayen said,

    May 22, 2006 @ 11:03 pm

    太好了,这几天就是在设计这个功能模块,太有用了!谢谢!

  9. alonesword said,

    September 29, 2006 @ 5:56 pm

    好东西,谢谢了,思想巧妙.想您学习!

  10. keeplinker said,

    December 22, 2006 @ 11:29 am

    谢谢.正在找这个属性呢.

  11. ie said,

    January 10, 2007 @ 7:08 pm

    IE7下根本不管用,IE6也不行 什么垃圾?

  12. bill said,

    August 14, 2008 @ 10:54 am

    谢谢分享。

  13. www.tbgame108.com said,

    December 31, 2015 @ 3:13 pm

    如果我们有着快乐的思想,我们就会快乐;如果我们有着凄惨的思想,我们就会凄惨。

RSS feed for comments on this post

Leave a Comment