Vue3+Koa2实现图片上传(不再畏惧)

2024-02-01 18:20

本文主要是介绍Vue3+Koa2实现图片上传(不再畏惧),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

大家好,我是勇宝,一个热爱前端的小学生,年关将至,提前祝大家新年快乐。今天呢,我们就来好好的啃一啃图片上传,从一个前端开发者的角度来探讨一下图片上传前后端到底都做了哪些事情。

文章目录

    • 一、技术摘要
    • 二、图片上传流程概述
      • 1. 前端
      • 2. 后端
    • 三、项目搭建
      • 前端
        • 1. 初始化Vue
      • 后端(koa2)
        • 1. 全局安装脚手架
        • 2. 初始化项目
        • 3. 运行
    • 四、开始撸代码
      • 1. 编写html骨架
      • 2. 定义回显元素
      • 3. 编写选择按钮逻辑
      • 4. 回显选择的图片
      • 5. 编写上传图片按钮
      • 6. 编写后端代码
      • 小结
    • 五、总结

一、技术摘要

本次实现的Demo使用到的技术主要有如下:

  • Vue3: 是一款用于构建用户界面的 JavaScript 框架。
  • koa: 基于 Node.js 平台的下一代 web 开发框架。

以上就是我们本次要用到的一些技术栈,我把官方也给大家贴心的贴出来了,方便大家学习,任何技术都离不开原生,大家多多举一反三。

二、图片上传流程概述

从概念的角度给大家伙梳理一下图片上传要做哪些事情。

1. 前端

首先我们要知道图片上传的一个大概的流程是什么,前端做点啥?后端做点啥?

我用最原生的方式给大家唠一唠,首先呢这个前端有一个<input id="file_upload" type="file" accept="image/*" />标签,这个大家应该没忘记吧。

一般我们是把这个input隐藏,自己写那么几个小按钮,通过点击按钮触发input点击事件(click)来选择要上传的图片对吧。

然后就是回显的方式,一般有两种:

  • 一种是等待后端处理好之后,response返回给我们前端然后去挂载。
  • 还有一种就是我们前端解析好之后去显示,这种比较好,不浪费服务器资源,哈哈哈。

最后的最后就是我们的请求头要改为multipart/form-data

2. 后端

首先是编写我们图片上传的接口uploads。因为这里我演示的是koa这个框架,所有后端我们使用到@koa/multur这个插件。

设置我们图片存放的路径(文件夹),当我们存储成功之后,再把图片信息存入我们的数据库(这一步就不给大家演示了,况且我也就会个MongoDB,就不献丑了),最后返回给前端成功的状态码

三、项目搭建

这一块没有什么难度,我们简单带过。

前端

1. 初始化Vue
// 初始化模版
npm init vue@latest
// 安装依赖
npm install
// 需要用到 axios HTTP请求
npm install axios --save

后端(koa2)

我千辛万苦找了一个生成koa的脚手架,还不错。

1. 全局安装脚手架
npm install koa-generator -g
2. 初始化项目
// serve是项目名称,可以自定义
koa2 serve
// 安装项目依赖
npm install
3. 运行
npm run dev

四、开始撸代码

前期工作准备好之后,开始进入我们的正题

1. 编写html骨架

我们就写两个按钮,一个用来选择图片,一个用来上传到后端

<template><div class="upload"><input type="file" accept="image/*" class="upload-file" ref="selectFileRef" /><div class="upload-btns"><button class="upload-select">选择图片</button><button class="upload-current">上传图片</button></div><!-- 用来回显我们的图片 --><div class="upload-preview"><img src="" alt="图片" /></div></div>
</template>
<script setup>
</script>
<style lang="scss" scoped>
.upload-file {
display: none;
}
</style>

2. 定义回显元素

如果我们的回显src是空的话,我们就让它隐藏。

<div class="upload-preview" v-show="previewUrl"><img src="" alt="图片" />
</div><script>
import { ref } from 'vue'
const previewUrl = ref('')
</script>

3. 编写选择按钮逻辑

使用ref获取inputDOM元素,通过点击选择图片按钮,触发input点击事件。

<button class="upload-select" @click="selectFileRef.click">选择图片</button>
......
......
// 获取input元素
const selectFileRef = ref(null)

此时我们点击选择图片,浏览器就会弹框,就可以选择我们要上传的图片啦!

4. 回显选择的图片

我们使用上边提到的第一种回显的方式,这样会减少http请求次数,减小服务器端压力。这里我们要监听input元素的change事件,当我们确定选择好图片之后会触发这个事件。具体如下:

<input type="file" accept="image/*" class="upload-file" ref="selectFileRef" @change="showImg" />
......
......const showImg = () => {// 获取我们上传的元素const file = selectFileRef.value.files[0]// 把图片转成base64const reader = new FileReader()reader.readAsDataURL(file)reader.onload = () => {// 给我们的回显元素赋值previewUrl.value = reader.result}}

5. 编写上传图片按钮

这是前端的最后一小步啦,这里我们主要注意请求header设置,还有数据类型{"Content-Type": "multipart/form-data"},并且这里我们使用到了axios

这里我就把axios直接拿过来用一下啦,以后有时间,我单独好好的和小伙伴们唠一唠怎么好好的对axios进行二次封装。

<button class="upload-current" @click="upload">上传图片</button>
......
......
// 编写上传文件的处理逻辑方法
const upload = () => {const file = selectFileRef.value.files[0]const formData = new FormData()formData.append('files', file)reader.onload = () => {previewUrl.value = reader.result}// 使用axios发起http请求axios({method: 'post',url: 'http://localhost:3000/uploads',headers: {'Content-Type': 'multipart/form-data'},data: formData}).then(res => {//这里是后端返回给我们的结果})
}

6. 编写后端代码

后端不作为我们的重点,大概给大家撸一下代码,主要是编写我们的app.js文件。还需要安装一下@koa/multer模块。

npm install @koa/multer

编写app.js

const Koa = require("koa");
const Router = require("koa-router");
const multer = require("@koa/multer");const app = new Koa();
const router = new Router();// 配置multer中间件
const upload = multer({storage: multer.diskStorage({//文件上传保存的路径destination: function (req, file, cb) {let dir = "./public/images"// 查看是否存在,不存在就创建if (!fs.existsSync(dir)) {fs.mkdirSync(dir, {recursive: true})}// 这里的路径必须要存在cb(null, dir)},//修改文件名称filename: function (req, file, cb) {const fileName = file.fieldname + "-" + Date.now() + path.extname(file.originalname)cb(null, fileName)}})
})// 编写图片上传的接口
router.post('/uploads', upload.single('files'), async ctx => {const filename = ctx.request.file.filenamepath = ctx.request.origin + '/images/' + filename// 这里可以去操作数据库把我们的url存入数据库中方便使用。ctx.body = {code: 200,message: '图片上传成功',url: path}
})
......
......
app.use(router.routes(), router.allowedMethods())app.listen(3000, () => {console.log('This is port 3000...')
})

小结

到此图片上传功能完成,大家可以愉快的玩耍啦。其实大家只要把该注意的点都写到基本就问题不大了。

五、总结

图片上传可以说是一个老生常谈的问题了,对于小白来说的我,每次看到就头大,但是这是不对的,我们应该有着一颗敢于探索敢于学习的精神,于是就决心狠狠的给它啃下。当你学会一项技能的时候就会发现,原来是如此简单(这是我作为小白的客观评价,大佬勿喷,哈哈哈)。遇到困难分两种:一种是知难而退、一种是迎难而上,这也是人和人之间有差距的根本原因

好了,今天就说道这把,大家共勉。

这篇关于Vue3+Koa2实现图片上传(不再畏惧)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/668077

相关文章

使用Python实现矢量路径的压缩、解压与可视化

《使用Python实现矢量路径的压缩、解压与可视化》在图形设计和Web开发中,矢量路径数据的高效存储与传输至关重要,本文将通过一个Python示例,展示如何将复杂的矢量路径命令序列压缩为JSON格式,... 目录引言核心功能概述1. 路径命令解析2. 路径数据压缩3. 路径数据解压4. 可视化代码实现详解1

PyQt6/PySide6中QTableView类的实现

《PyQt6/PySide6中QTableView类的实现》本文主要介绍了PyQt6/PySide6中QTableView类的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学... 目录1. 基本概念2. 创建 QTableView 实例3. QTableView 的常用属性和方法

PyQt6/PySide6中QTreeView类的实现

《PyQt6/PySide6中QTreeView类的实现》QTreeView是PyQt6或PySide6库中用于显示分层数据的控件,本文主要介绍了PyQt6/PySide6中QTreeView类的实现... 目录1. 基本概念2. 创建 QTreeView 实例3. QTreeView 的常用属性和方法属性

Android使用ImageView.ScaleType实现图片的缩放与裁剪功能

《Android使用ImageView.ScaleType实现图片的缩放与裁剪功能》ImageView是最常用的控件之一,它用于展示各种类型的图片,为了能够根据需求调整图片的显示效果,Android提... 目录什么是 ImageView.ScaleType?FIT_XYFIT_STARTFIT_CENTE

pandas中位数填充空值的实现示例

《pandas中位数填充空值的实现示例》中位数填充是一种简单而有效的方法,用于填充数据集中缺失的值,本文就来介绍一下pandas中位数填充空值的实现,具有一定的参考价值,感兴趣的可以了解一下... 目录什么是中位数填充?为什么选择中位数填充?示例数据结果分析完整代码总结在数据分析和机器学习过程中,处理缺失数

Golang HashMap实现原理解析

《GolangHashMap实现原理解析》HashMap是一种基于哈希表实现的键值对存储结构,它通过哈希函数将键映射到数组的索引位置,支持高效的插入、查找和删除操作,:本文主要介绍GolangH... 目录HashMap是一种基于哈希表实现的键值对存储结构,它通过哈希函数将键映射到数组的索引位置,支持

Pandas使用AdaBoost进行分类的实现

《Pandas使用AdaBoost进行分类的实现》Pandas和AdaBoost分类算法,可以高效地进行数据预处理和分类任务,本文主要介绍了Pandas使用AdaBoost进行分类的实现,具有一定的参... 目录什么是 AdaBoost?使用 AdaBoost 的步骤安装必要的库步骤一:数据准备步骤二:模型

使用Pandas进行均值填充的实现

《使用Pandas进行均值填充的实现》缺失数据(NaN值)是一个常见的问题,我们可以通过多种方法来处理缺失数据,其中一种常用的方法是均值填充,本文主要介绍了使用Pandas进行均值填充的实现,感兴趣的... 目录什么是均值填充?为什么选择均值填充?均值填充的步骤实际代码示例总结在数据分析和处理过程中,缺失数

Java对象转换的实现方式汇总

《Java对象转换的实现方式汇总》:本文主要介绍Java对象转换的多种实现方式,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录Java对象转换的多种实现方式1. 手动映射(Manual Mapping)2. Builder模式3. 工具类辅助映

Go语言开发实现查询IP信息的MCP服务器

《Go语言开发实现查询IP信息的MCP服务器》随着MCP的快速普及和广泛应用,MCP服务器也层出不穷,本文将详细介绍如何在Go语言中使用go-mcp库来开发一个查询IP信息的MCP... 目录前言mcp-ip-geo 服务器目录结构说明查询 IP 信息功能实现工具实现工具管理查询单个 IP 信息工具的实现服