HTML文件上传域

KuaiKan 2021-7-27 659

文件上传是网站中一种常见的功能。例如百度网盘、QQ 邮箱以及有道云笔记都可以实现文件的上传。在 HTML 中,把 <input> 标签的 type 属性设置为 file 就可以实现上传文件的功能,又叫做文件上传域。具体语法格式如下:

<input type="file"/>

接下来我们看一下怎样才能实现文件的正确上传呢?具体代码如下:

<form action="https://xxx.xxxx.xxx/register.asp" method="post" enctype="multipart/form-data">
     <input type="file" name="file" accept="image/png"/><br/>
     <input type="submit"/>
</form>

上传文件时,需要把 method 属性设置为 post(get 方式不能提交文件)。

上述代码中,使用了 <form> 标签的 enctype 属性以及 <input> 标签的 accept 属性,我们来分别看一下: 

1. enctype属性

enctype 属性规定被提交数据的编码。如果提交数据中包含文件时,需要把 <form> 标签的 enctype 属性设置为 multipart/form-data。如果不这样设置,文件将无法正常提交。具体代码如下:

<form action="https://xxx.xxxx.xxx/register.asp" method="post" enctype="multipart/form-data">
     <input type="file" name="file"/><br/>
     <input type="submit"/>
</form>

运行结果如图所示:

enctype

当然仅仅设置<form> 标签的 enctype  属性是不够的,如果要保证文件可以正确提交给表单服务器,还需要设置文件的类型,这时就需要使用 accept 属性。

2. accept属性

当 <input> 标签的 type 属性为 file 时,使用 accept 属性可以规定上传文件的类型。具体代码如下:

<form action="https://xxx.xxxx.xxx/register.asp" method="post" enctype="multipart/form-data">
      <input type="file" name="file" accept="image/png"/>
</form>

此处规定上传的文件只能是.png格式的图片。如果想上传.pdf格式的图片,需要修改accept 的属性值

上传文件的类型有很多种,我们在文章的末尾会附上常用的文件类型。

如果 accept 的属性值为多个,它们之间需要用逗号隔开。

根据以上内容,我们总结出上传文件需要注意的 2 点:

  • 把 <form> 标签的 enctype 属性设置为 multipart/form-data;

  • 使用 <input> 标签的 accept 属性来设置上传文件的类型。

然而这样编写代码只能实现每次上传一个文件,如果想实现一次上传多个文件,还要用到 <input> 标签的 multiple 属性。

3. multiple属性

当给上传文件字段设置了 multiple 属性时,就表示可以同时选择多个文件一起上传。我们来看具体的代码:

<form action="https://xxx.xxxx.xxx/register.asp" method="post" enctype="multipart/form-data">
      <input type="file" name="file" accept="image/png" multiple />
</form>

这时我们就可以一次性选择多个.png格式的图片文件,如图所示:

multiple

通过运行结果可以发现,当选择多个文件时,浏览器显示的是文件个数而不再是文件名称。

4. 常用的文件类型

 常用的文件类型

常用文件类型对应的 accept 属性值
.jpgimage/jpg
.pngimage/png
.gifimage/gif
.jpegimage/jpeg
.htmltext/html
.csstext/css
.jstext/javascript、application/javascript
.txttext/plain
.zipapplication/zip
.mp4audio/mp4、video/mp4


签名:这个人很懒,什么也没有留下!
最新回复 (0)
返回