我使用了以下方法
HTML
<input type="file" id="loadfile" />
的JavaScript
var file = document.getElementById('loadfile').files[0];
alert( "name " + file.name + "Size " + file.size );
除了IE之外,其他浏览器都很好:( 如何进入IE?
答案 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");
}