如何在IE中使用javascript从客户端获取文件大小?

时间:2012-11-22 11:39:44

标签: javascript jquery internet-explorer file-upload

我使用了以下方法

HTML

<input type="file" id="loadfile" />

的JavaScript

var file = document.getElementById('loadfile').files[0];
alert( "name " +  file.name + "Size " +  file.size );

除了IE之外,其他浏览器都很好:( 如何进入IE?

5 个答案:

答案 0 :(得分:5)

IE不提供我害怕的文件大小信息。您可以在IE10中使用HTML5 File API,请参阅此处: -

Javascript to check filesize before upload in Internet Explorer

答案 1 :(得分:1)

你可以使用activeX

这样做
function getSize()
{
 var myFSO = new ActiveXObject("Scripting.FileSystemObject");
 var filepath = document.upload.file.value;
 var thefile = myFSO.getFile(filepath);
 var size = thefile.size;
 alert(size + " bytes");
}

请点击此处了解更多详情;

how validate file size using HTML and Javascript on client side

答案 2 :(得分:1)

document.getElementById('loadfile').addEventListener('change', checkFile, false);

function checkFile(e) {
    var file_list = e.target.files;
    for (var i = 0, file; file = file_list[i]; i++) {
        var fileExtension = file.name.split('.')[file.name.split('.').length - 1].toLowerCase();
        var iConvert = (file.size / 1024).toFixed(2);

        txt = "File type : " +fileExtension + "\n";
        if(file.size > (1024 * 1024)){
            txt += "Size: " + (file.size / (1024*1024)).toFixed(2) + " MB \n";
        } else {
        txt += "Size: " + (file.size / 1024).toFixed(2) + " KB \n";
        }
        alert(txt);
    }
}

请参阅filddle

答案 3 :(得分:0)

IE版本9不支持获取文件大小所需的file API。 IE10不支持文件大小。

答案 4 :(得分:0)

IE不支持File API

来源:https://github.com/blueimp/jQuery-File-Upload/issues/147

必须使用ActiveX控件来执行此操作

function getSize()
{
 var myFSO = new ActiveXObject("Scripting.FileSystemObject");
 var filepath = document.upload.file.value;
 var thefile = myFSO.getFile(filepath);
 var size = thefile.size;
 alert(size + " bytes");
}

来源:http://www.sencha.com/forum/showthread.php?196859-File-Upload-Field-IE-Safari-Opera-fileInput-error.&s=b124834725ae363759158268d91ac32c