我有一个文件上传对象在我的页面上:

<input type="file" ID="fileSelect" />

在我的桌面上有以下excel文件:

file1.xlsx file1.xls file.csv

我想上传的文件只显示.xlsx, .xls, & .csv文件。

使用accept属性,我发现这些内容类型负责.xlsx和.xls扩展…

接受应用程序/ vnd.openxmlformats-officedocument.spreadsheetml =。表(.XLSX) 接受=应用程序/盾。ms excel (xls)

但是,我找不到Excel CSV文件的正确内容类型!有什么建议吗?

例如:http://jsfiddle.net/LzLcZ/


当前回答

只写你想要接受的扩展,在动作atr中以逗号分隔

<input type="file" accept=".any, .ext, .you, .want">

其他回答

现在你可以只使用文件扩展名

<input type="file" ID="fileSelect" accept=".xlsx, .xls, .csv"/>

Dom这个属性非常古老,据我所知,在现代浏览器中不被接受,但这里有一个替代方案,试试这个

<script type="text/javascript" language="javascript">
function checkfile(sender) {
    var validExts = new Array(".xlsx", ".xls", ".csv");
    var fileExt = sender.value;
    fileExt = fileExt.substring(fileExt.lastIndexOf('.'));
    if (validExts.indexOf(fileExt) < 0) {
      alert("Invalid file selected, valid files are of " +
               validExts.toString() + " types.");
      return false;
    }
    else return true;
}
</script>

<input type="file" id="file" onchange="checkfile(this);" />

我想它会帮助你当然你可以根据你的需要更改这个脚本。

只写你想要接受的扩展,在动作atr中以逗号分隔

<input type="file" accept=".any, .ext, .you, .want">

这太尴尬了……我找到了我一直在寻找的解决方案,而且再简单不过了。我使用以下代码来获得所需的结果。

<标签= " fileSelect " >表格> < /标签 <input id="fileSelect" type="file" accept=".csv, application/vnd.openxmlformats-officedocument.spreadsheetml。盾板,应用程序/。ms excel " / >

有效的接受类型:

对于CSV文件(.csv),使用:

<input type="file" accept=".csv" />

对于Excel Files 97-2003 (.xls),请使用:

<input type="file" accept="application/vnd.ms-excel" />

对于Excel Files 2007+ (.xlsx),使用:

<input type="file" accept="application/vnd.openxmlformats-officedocument.spreadsheetml.sheet" />

对于文本文件(.txt)使用:

<input type="file" accept="text/plain" />

对于图像文件(.png/.jpg/etc),使用:

<input type="file" accept="image/*" />

对于HTML文件(.htm,.html),使用:

<input type="file" accept="text/html" />

对于视频文件(。Avi, .mpg, .mpeg, .mp4),使用:

<input type="file" accept="video/*" />

对于音频文件(.mp3, .wav等),使用:

<input type="file" accept="audio/*" />

对于PDF文件,请使用:

<input type="file" accept=".pdf" /> 

演示: http://jsfiddle.net/dirtyd77/LzLcZ/144/


注意:

如果您试图显示Excel CSV文件(.csv),请不要使用:

文本/ csv 应用程序/ csv 文本/逗号分隔值(仅适用于Opera)。


如果你试图显示一个特定的文件类型(例如,WAV或PDF),那么这将几乎总是工作…

 <input type="file" accept=".FILETYPE" />

原因如下:

应用程序类型通常意味着打开文件的位置。 例如,Abode Reader。 但是当这个文件上传时,浏览器并不关心打开并询问该应用程序。但扩展,然而,或键入字,如MIME图像或音频等工作直接应用到文件单元。

可以将它们与File DOM实例关联使用。 因此,您应该使用扩展格式名称。 在许多设备上,如手机,它是看到当你点击选择文件,非接受的文件在用户菜单中被排除在灰色… 有一个伟大的时间花在您的文件!

我修改了@yogi的解决方案。另外,当文件格式不正确时,我重置输入元素值。

function checkFile(sender, validExts) {
  var fileExt = sender.value;
  fileExt = fileExt.substring(fileExt.lastIndexOf('.'));
  if (validExts.indexOf(fileExt) < 0 && fileExt != "") {
    alert("Invalid file selected, valid files are of " +
             validExts.toString() + " types.");
    $(sender).val("");
    return false;
  }
  else return true;
}

我有自定义验证内置,因为在打开的文件窗口中,用户仍然可以选择选项“所有文件('*')”,无论我是否显式地设置输入元素中的接受属性。