js或jquery file.type.match仅适用于jpg和png

问题描述 投票:3回答:2

如何使用file.type.match仅限制png和jpg的mimetype

下面是我的代码

var fileInput = document.getElementById("myfileinput").files[0];

if (fileInput.type.match('image/jpeg'))  
      //I not thinking to use if(xx || xx)
      //prefer using var mimeType = jpg,png  many tries but not work
{
alert("Right");
}else{
alert("wrong");
}
javascript jquery mime-types
2个回答
7
投票

从你的问题来看,这听起来像你不想做的事情:

if (fileInput.type.match('image/jpeg') || fileInput.type.match('image/png'))  
  //I not thinking to use if(xx || xx)
  //prefer using var mimeType = jpg,png  many tries but not work
{
  alert("Right");
}else{
  alert("wrong");
}

您可以创建一个可接受的扩展数组并循环遍历它们,如:

var fileInput = document.getElementById("myfileinput").files[0];
var allowed = ["jpeg", "png"];
var found = false;

allowed.forEach(function(extension) {
  if (fileInput.type.match('image/'+extension)) {
    found = true;
  }
})

if(found) {
  alert("Right");
}
else{
  alert("wrong");
}

请参阅此fiddle进行测试。


0
投票

它也可以用|作为OR运算符在一行中完成:

if (fileInput.type.match('image/jpeg|image/png')) {...}

© www.soinside.com 2019 - 2024. All rights reserved.