网站首页 > 技术文章 正文
转载说明:原创不易,未经授权,谢绝任何形式的转载
在开发前端应用程序时,有时我们可能需要允许用户上传图像文件。稍后,我们可以处理图像文件,并在必要时将其发送到后端进行进一步处理和存储。最常见的图像文件格式是PNG、JPEG和JPG。
当用户上传图片时,我们必须首先将文件内容嵌入为base64或文件,并将信息附加到formData中,然后再将其与请求体一起发送。
将图像文件嵌入formData时,必须将其作为键值对包含在内。键应表示包含图像文件的主体数据的名称,相应的值应包含实际的图像文件。我们还需要确保设置正确的头部编码类型为 multipart/form-data 。
multipart/form-data 是一种HTML表单编码类型,用于当我们的表单包含任何 <input type="file"> 元素时使用。当一个表单包含文件输入时,必须在HTML表单标签的enctype属性中使用"multipart/form-data",以确保在服务器端进行正确的数据传输和处理。
formData提供了一个我们可以使用各种操作来操作的对象。其中一些最常见的操作包括:
- formData.append():用于向指定对象键添加新值。
- formData.get(): 用于检索与特定键关联的第一个值。
- formData.delete(): 用于从formData对象中删除键/值对。
图片上传
<script setup lang="ts">
import { ref } from 'vue'
import axios from 'axios';
const selectedFile = ref();
async function onFileSelected(event: Event) {
if (!event.target)
return
const target = event.target as HTMLInputElement
if (!target.files) {
// toastError('No image selected')
return
}
console.log(target.files)
selectedFile.value = target.files
}
async function submitImageForm(){
const config = {
headers: {
"Content-Type": "multipart/form-data",
},
};
try{
// Your backend endpoint for image upload
const uploads_url = 'https://api.your-backend-url.com/upload';
let formData = new FormData();
formData.append("photo", selectedFile.value);
const res = await axios.post(`${uploads_url}`, formData, config);
const data = await res.json();
console.log(data)
}catch(error: unknown){
// Catch errors here and handle them accordingly
if (axios.isAxiosError(error) && error.response) {
console.log(error.response.data.message)
return
}
// handle other errors here
console.log(error)
}
}
</script>
<template>
<h2>Upload Image</h2>
<form method="post" enctype="multipart/form-data">
<label for="image">Select an image to upload:</label>
<input type="file" id="image" name="image" accept="image/*" @change="onFileSelected">
<br>
<input type="submit" value="Upload Image" @click="submitImageForm">
</form>
</template>
有一件重要的事情需要注意,那就是确保您使用与后端期望的formData一致的正确键名。这是必要的,因为它作为上传图像数据的标识符,并且后端将使用它来访问请求负载中的图像。
当您需要上传多个图片时,您可以像这样将 multiple 属性传递给输入字段。
<input
id="image"
type="file"
name="image"
accept="image/*"
@change="onFileSelected"
multiple
/>
当您将上传的图像内容记录到控制台时,您将收到类似于下面截图示例中显示的元数据。
结论
我们已经看到了如何上传图像文件,提取图像数据,将其附加到formData中,并使用适当的头部编码类型将其发送到后端。
由于文章内容篇幅有限,今天的内容就分享到这里,文章结尾,我想提醒您,文章的创作不易,如果您喜欢我的分享,请别忘了点赞和转发,让更多有需要的人看到。同时,如果您想获取更多前端技术的知识,欢迎关注我,您的支持将是我分享最大的动力。我会持续输出更多内容,敬请期待。
猜你喜欢
- 2025-06-15 Nodejs文件上传、监听上传进度(node监听文件变化)
- 2025-06-15 Express 文件上传不迷路:req.files 一次性讲明白
- 2025-06-15 JAVA大文件上传,大文件下载解决方案
- 2025-06-15 深入掌握 OSS:最完美的 OSS 上传方案!
- 2025-06-15 AspNetCore中的文件上传与下载优化
- 2025-06-15 【前后台完整版】大文件分片上传(大文件分片上传速度快么)
- 2025-06-15 js获取上传文件类型以及大小的方法
- 2024-10-04 JAVAWEB 文件上传及下载 java文件的上传和下载
- 2024-10-04 用JAVA实现大文件上传及显示进度信息
- 2024-10-04 常用JSP文件上传,下载的一些方法 常用jsp文件上传,下载的一些方法叫什么
你 发表评论:
欢迎- 527℃Oracle分析函数之Lag和Lead()使用
- 526℃几个Oracle空值处理函数 oracle处理null值的函数
- 523℃Oracle数据库的单、多行函数 oracle执行多个sql语句
- 508℃0497-如何将Kerberos的CDH6.1从Oracle JDK 1.8迁移至OpenJDK 1.8
- 506℃Oracle 12c PDB迁移(一) oracle迁移到oceanbase
- 497℃【数据统计分析】详解Oracle分组函数之CUBE
- 477℃最佳实践 | 提效 47 倍,制造业生产 Oracle 迁移替换
- 475℃Oracle有哪些常见的函数? oracle中常用的函数
- 最近发表
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端react (48)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端富文本编辑器 (47)
- 前端路由 (61)
- 前端数组 (73)
- 前端排序 (47)
- 前端定时器 (47)
- Oracle RAC (73)
- oracle恢复 (76)
- oracle 删除表 (48)
- oracle 用户名 (74)
- oracle 工具 (55)
- oracle 内存 (50)
- oracle 导出表 (57)
- oracle 中文 (51)
- oracle的函数 (57)
- 前端调试 (52)
- 前端登录页面 (48)
本文暂时没有评论,来添加一个吧(●'◡'●)