H5文件上传

简介: H5文件上传

在工作中,文件上传功能是经常遇到的问题,但是我们基本上都是用组件去解决文件上传的问题,很少有人会去了解和通过原生的方式去手动实现一下文件上传,今天来通过原生的方式进行实现一下完整的操作

页面结构

首先我们写一个input文件选择框,用于选择文件,还可以给input添加上multiple属性开启多选,在写一个button按钮用于操控文件上传,上面绑定一了个FileUpload方法,里面是文件上传的操作

<input type="file" id="file" multiple/>
<button onclick="FileUpload()">上传文件</button>

文件上传

我们通过js获取id元素的方法获取到文件上传框的DOM元素,在根据DOM元素下的files属性获取到上传的文件信息列表,里面每一项都是一个file对象,包含了文件名字,文件大下,文件类型等信息,然后创建一个formData构造的函数实例,便于我们操作或存储file文件向后端传输,由于我们获取到的file文件列表是一个伪数组,所以我们这里使用Array.form方法将他转化为真正的数组,在使用数组上的map方法进行循环使用formData实例上的append方法往里面追加数据,追加后的数据可以通过formData实例上的get方法进行读取文件信息,这里我们无法通过正常的console.log方法读取到formData实例上的数据,因为formData构造函数是一种特殊的对象类型,无法进行序列化数据,所以我们通过console.log打印的直接就是formData原型,将数据追加进该实例之后,就可以通过后端的接口向后端进行传输

function FileUpload() {
            const files = document.getElementById('file').files;
            const formData = new FormData();
           Array.from(files).map(R=>{
                console.log(R);
                formData.append('photos', files);
            })
            //读取
           // formData.get("file");
            //上传文件代码省略
        }

在发送请求的时候我们需要注意,我们需要将请求头的content-type属性设置为multipart/form-data,设置成该属性之后我们往后端传递就会是一个文件流,后端进行处理的话也比较方便

坚持努力,无惧未来!

相关文章
C#文件上传
C#文件上传
60 0
|
6天前
|
存储 PHP 文件存储
32 单文件上传
路老师分享PHP文件上传教程,涵盖配置php.ini、使用$_FILES变量和move_uploaded_file()函数等关键步骤,帮助你轻松实现单文件上传功能。纯干货,技术知识分享。
20 1
|
11天前
|
Java
smartupload文件上传!
使用 `smartupload.jar` 实现文件上传和下载。首先将 `smartupload.jar` 添加到项目中,然后创建上传页面,确保表单使用 `POST` 方法并设置 `enctype=&quot;multipart/form-data&quot;`。接着在服务器端通过 `SmartUpload` 对象处理文件上传,保存文件到指定目录,并获取表单中的其他数据。最后,实现文件下载功能,设置响应头以触发浏览器下载文件。
19 0
|
6月前
|
JSON 数据格式
文件上传~~
文件上传~~
45 0
|
3月前
|
前端开发 JavaScript 数据库
多个文件上传
多个文件上传
31 0
|
JavaScript 前端开发 移动开发
浅谈文件上传
浅谈文件上传
浅谈文件上传
|
安全 应用服务中间件 PHP
[SUCTF 2019]CheckIn(文件上传)
[SUCTF 2019]CheckIn(文件上传)
165 0
|
开发框架 安全 JavaScript
文件上传利用总结
文件上传利用总结
362 0
|
JavaScript
你真的了解文件上传吗?
你真的了解文件上传吗?