客户端js判断文件类型和文件大小即限制上传大小

  

客户端JS判断文件类型和文件大小即限制上传大小是常见的一个需求。以下是操作的完整攻略:

1.判断文件类型

  • 第一种方法:使用HTML5的file API

使用HTML5的file API可以获取文件的信息,包括文件类型,如下:

const fileInput = document.getElementById('file');
const file = fileInput.files[0];

if (file.type === 'image/png' || file.type === 'image/jpeg') {
  // 文件类型为png或jpeg
} else {
  // 文件类型不符合要求
}
  • 第二种方法:使用正则表达式

使用正则表达式判断文件扩展名是否符合要求,如下:

const fileInput = document.getElementById('file');
const fileName = fileInput.value;
const regex = /^.*(\.png|\.jpg|\.jpeg)$/;

if (regex.test(fileName.toLowerCase())) {
  // 文件类型为png,jpg或jpeg
} else {
  // 文件类型不符合要求
}

2.限制上传文件大小

  • 第一种方法:使用HTML5的file API

使用HTML5的file API可以获取文件的大小,如下:

const fileInput = document.getElementById('file');
const file = fileInput.files[0];

const fileSize = file.size / 1024 / 1024; // 获取文件大小,单位为MB

if (fileSize > 5) { // 文件大小限制为5MB
  // 文件大小超过限制
} else {
  // 文件大小符合要求
}
  • 第二种方法:使用onchange事件结合FormData

使用onchange事件结合FormData可以获取文件的大小,如下:

const fileInput = document.getElementById('file');
let formData = null;

fileInput.addEventListener('change', (event) => {
  const file = event.target.files[0];
  formData = new FormData();

  formData.append('file', file);

  if (file.size / 1024 / 1024 > 5) { // 文件大小限制为5MB
    // 文件大小超过限制
  } else {
    // 文件大小符合要求
  }
});

以上是客户端JS判断文件类型和文件大小即限制上传大小的完整攻略,希望对您有所帮助。

相关文章