相关技巧

关注公众号 jb51net

关闭
首页 > 网络编程 > 相关技巧 > input文件上传的accept属性

input的accept属性让文件上传安全高效

作者:@大迁世界

文章介绍了HTML的input文件上传`accept`属性在文件上传校验中的重要性和优势,通过使用`accept`属性,可以减少前端JavaScript的复杂性,提高用户体验,并且在大多数主流浏览器中都有很好的支持

前言

大部分前端开发,一提到“文件上传校验”,脑子里立刻蹦出三件事:

然后——自然地把这些事全扔给 JavaScript。

看起来很专业,对不对?直到有一天,我上传了一个文件,还没等它到后端,就被自己前端逻辑搞崩了。

于是我开始往代码里疯狂加条件、加双重判断、加“测试用特例”, 结果越补越乱,越写越心虚。

也就是在那段时间,我无意间翻出一个自己“从来没当回事”的 HTML 小特性。

这个小东西,直接改变了我处理文件上传的方式。

今天就把这个发现,从头讲给你听。

那个悄悄毁掉你上传体验的“常见写法”

大部分人处理上传,基本都是这样写:

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

然后再配套一段 JavaScript 做校验:

const fileInput = document.getElementById('ImageUpload');

fileInput.addEventListener('change', (e) => {
  const inputFile = e.target.files[0];

  if (!inputFile.type.startsWith("image/")) {
    alert("You can upload only images.");
  }
});

写完之后,内心是有点成就感的:

“你看,我可以提示用户:你选错文件类型啦~”

但问题来了:

然后你跳出来说:

“不行哦,这个传不上来。”

这就是典型的——事后教育式交互。 拖慢体验不说,错误率还高得离谱。

更扎心的是: 即便你写了这段 JavaScript 校验, 依然会遇到各种奇奇怪怪的测试样例:

也就是说:

你费劲写了一堆前端验证, 但它既拦不住真高手,也常常在烦普通用户。

直到我遇见今天的主角。

改变一切的 HTML 小特性:accept

我说的就是这个东西:

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

一个几乎所有人都见过、 却没几个人认真用过的属性:**accept**。

它小到只有几个字符, 但给上传体验带来的改变,是维度级别的:

一句话:

用户选不到错的文件, 你就少写一半“事后骂人”的 JavaScript。

真正的魔法:让用户一开始就没机会选错

当你这么写:

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

接下来会发生什么?

在这个阶段, 你的 JavaScript 甚至还没出场, 用户就已经被温柔地“拦在正确的范围里”。

如果你要上传的是 PDF 呢?

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

再复杂一点,比如: 你想允许用户上传 多种类型:图片 + PDF:

<input type="file" accept=".png, .jpg, .jpeg, .pdf" />

只想要视频?

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

只要音频?

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

只要 Office 文件(Word / Excel / PPT)?

<input type="file" accept=".docx, .xlsx, .pptx" />

这些全都只是 HTML 在帮你干活。 你甚至不需要写一行 JS, 就能把 90% 的“明显错误文件”挡在门外。

那如果我需要更精细的控制呢?

当然,现实项目里,你往往不只关心“格式对不对”。 比如:

“必须是 PDF,且不能超过 2MB。”

这时候你就不用搞“二选一”——

不是“要么用 accept”, 也不是“只用 JS 校验”。

最聪明的做法,是:两者叠加使用

先用 HTML 把格式错得离谱的全部挡掉, 再用 JavaScript 做更细节的逻辑,比如文件大小。

举个简化版例子:

<input type="file" id="resumeFile" accept=".pdf" />
document.getElementById("resumeFile").addEventListener("change", (e) => {
  const file = e.target.files[0];

  if (file.size > 2 * 1024 * 1024) {
    alert("You can upload the file of maximum 2MB only.");
    e.target.value = ""; // 清空选择
  }
});

这样一来:

到了后端,你再进行最终验证:

这才是一个真正安全又顺滑的上传流程:

第一道关:accept(友好 + 直观)

第二道关:前端 JS(体验 + 提前反馈)

第三道关:后端校验(绝对安全兜底)

多种文件类型的“精确过滤”,完全不需要第三方库

很多时候,你上传的不是“所有图片”, 而是特定格式,比如只要 PNG 和 MP4。

以前很多人第一反应是: “写个复杂点的正则吧。”

但其实,只要这样写就够了:

<input type="file" accept="image/png, video/mp4" />

再比如,你的后台只接受 CSV:

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

这背后复杂的 MIME 映射、兼容性细节、各种边界情况, 浏览器已经帮你扛了大半。

你只要静静地写对 accept 里的字符串就行。

不用上第三方组件, 不用写一堆莫名其妙的兼容代码, HTML 本身就足够强。

浏览器支持情况:能跑的地方,几乎都能用

很多人听到这里,第一个问题是:

“这么好用,会不会只在个别浏览器有效?”

简单给你一句话版结论:

accept 属性,在主流平台上几乎是全量支持

也就是说: 你可以非常安心地在正常项目里,上这个属性。

再强调一次:不是说不要 JS,而是别让 JS 做本不该它做的事

我并不是说:

“用 HTML 就够了,JavaScript 都删掉吧。”

JavaScript 在上传逻辑里,依然非常重要:

这些都是 HTML 做不到的地方。

我想说的是:

有些事情,HTML 已经帮你想好了, 你再用 JS 去重复造轮子, 不仅费力,还容易写出 bug。

有时候,一行写错的 JS, 能让你整个上传逻辑直接翻车; 而一个正确的 HTML 属性, 则可以在问题发生之前,就悄悄帮你挡掉一半错误输入。

常见文件类型对应的MIME类型:

文件类型扩展名MIME类型
JPEG图像.jpg, .jpegimage/jpeg
PNG图像.pngimage/png
GIF图像.gifimage/gif
WebP图像.webpimage/webp
SVG图像.svgimage/svg+xml
PDF文档.pdfapplication/pdf
Word文档.docapplication/msword
Word文档.docxapplication/vnd.openxmlformats-officedocument.wordprocessingml.document
Excel文件.xlsapplication/vnd.ms-excel
Excel文件.xlsxapplication/vnd.openxmlformats-officedocument.spreadsheetml.sheet
PPT文件.pptapplication/vnd.ms-powerpoint
PPT文件.pptxapplication/vnd.openxmlformats-officedocument.presentationml.presentation
文本文件.txttext/plain
HTML文件.html, .htmtext/html
CSS文件.csstext/css
JavaScript.jsapplication/javascript
JSON文件.jsonapplication/json
XML文件.xmlapplication/xml
ZIP压缩.zipapplication/zip
RAR压缩.rarapplication/x-rar-compressed
7Z压缩.7zapplication/x-7z-compressed
MP3音频.mp3audio/mpeg
WAV音频.wavaudio/wav
OGG音频.oggaudio/ogg
MP4视频.mp4video/mp4
AVI视频.avivideo/x-msvideo
MOV视频.movvideo/quicktime

最后的小结:学会用好这一行,你会讨厌你以前的写法

如果你今天只能带走一件事,那就是:

下次写 <input type="file"> 的时候, 先想想:“我到底允许什么类型?”

然后,老老实实写上 accept

从此以后,你会发现:

HTML 没有突然变聪明。 只是我们过去很多年, 把它当成了“只能画表单的塑料壳”, 忘了它其实有很多细腻的小能力,可以让体验变得更优雅。

写得越久,我越服的一句话是:

代码不一定要写得花哨, 但一定要优先把 已有的好工具,用明白。

accept 就是这样的工具之一。

用过一次,你就再也不会回去写那种: “上来不设限制、事后狂 alert 用户”的上传逻辑了。

accept 属性是提高用户体验的重要工具,但需要注意:

到此这篇关于input的accept属性让文件上传安全高效的文章就介绍到这了,更多相关input文件上传的accept属性内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

您可能感兴趣的文章:
阅读全文