vue 实现文件上传

article/2025/6/21 0:01:58

(一)首先实现html、css布局

代码:

<template><div class="image-uploader"><img :src="uploadIcon" class="icon"/> <p>Drag your images here</p><p>OR</p><div class="real-btn">SELECT A FiLE<input type="file" @change="inputChange" class="hide-btn"></div></div>
</template><script>
import uploadIcon from '../assets/upload.png'
export default {name: 'imageUpload',data () {return {uploadIcon: uploadIcon}}
}
</script><style scoped>
.image-uploader {margin: 20px;border: 3px dashed #fff;background: #2196F3;padding: 10px;text-align: center;color: #fff;border-radius: 10px;font-weight: 500;
}
.real-btn {cursor: pointer;position: relative;padding: 10px 20px;background: #fff;border-radius: 10px;color: #2196F3;
}
.hide-btn {width: 100%;height: 100%;top: 0;left: 0;position: absolute;opacity: 0;
}
.icon {width: 50px;height: 50px;
}
</style>

到这一步,样式就算是写完了

注意!!

由于只有 input 的 type 等于 file 的时候才能调起电脑文件夹,所以 SELECT A FiLE 这个按钮是与 <input type="file"> 这个元素重叠的,点击 SELECT A FiLE 这个按钮其实是 点击 <input type="file">,然后将 input 这个标签隐藏

最后通过 opacity: 0;将真实的input 隐藏

(二)实现拖拽上传

(1)实现拖拽的效果需要 使用两个方法:dragEnter、dragLeave

这时候又遇到坑了,我在最外层父元素上绑定 dragEnter、dragLeave

当将图片在父元素区域内拖动时,会不断触发 dragEnter、dragLeave,而不是 只有进来和出去触发,经过了解解释如下:

它是每进入一个新元素的同时就退出上一个元素,当退出父元素时,就不会有下一个进入的元素了, 所以进入的元素与退出的的元素相等,所以我们需要记录上次移入的节点

// 拖拽进入上传文件区dragEnter (e) {this.currentTarget = e.target // 当前进入的元素this.isDragging = true},// 拖拽离开上传文件区dragLeave (e) {if (e.target === this.currentTarget) {this.isDragging = false}}

 (2)拖拽进去松手之后

触发 drop 事件

drop (e) {this.isDragging = false// 解决 e.dataTransfer.files 经常为空的问题var file = []file.forEach.call(e.dataTransfer.files, function (item) {file.push(item)}, false)},

拖进去的文件 在 e.dataTransfer.files 这个字段里,我们需要转成数组

 

(3)通过 input 上传

<input type="file" @change="inputChange" class="hide-btn">
 async inputChange (e) {const base64 = await this.getBase64(e.target.files[0])this.getImageUrl(base64, e.target.files[0].name)},

上传结果图:

完整代码:

<template><div class="image-uploader"@dragenter="dragEnter"@dragleave="dragLeave"@drop.prevent="drop"@dragover.prevent:class="[ isDragging ? 'isDraging' : '' ]"> <img :src="uploadIcon" class="icon"/><p>Drag your images here</p><p>OR</p><divclass="real-btn":class="[ isDragging ? 'isDraging-btn' : '' ]">SELECT A FILE<input type="file" @change="inputChange" class="hide-btn"></div><!-- 上传图片展示列表 --><div v-show="files.length > 0" class="file-list"><divv-for="(fileItem) in files":key="fileItem.index"class="list-item"><img :src="fileItem.url" alt=""><div>{{ fileItem.name }}</div></div></div></div>
</template><script>
import uploadIcon from '../assets/upload.png'
import axios from 'axios'
export default {name: 'imageUpload',data () {return {uploadIcon: uploadIcon,isDragging: false, // 是否正在拖拽currentTarget: null, // 上一个dragEnter的元素files: [] // 文件上传列表}},methods: {// 拖拽进入上传文件区dragEnter (e) {this.currentTarget = e.targetthis.isDragging = true},// 拖拽离开上传文件区dragLeave (e) {if (e.target === this.currentTarget) {this.isDragging = false}},// drop 是指将文件拖入父元素 松手触发的操作// 必须阻止 dragover 的默认行为 不然 drop 不生效// drop 也要阻止默认行为 不然拖进去后 浏览器自动打开该文件drop (e) {this.isDragging = false// 解决 e.dataTransfer.files 经常为空的问题// 把累数组转化成数组var file = []file.forEach.call(e.dataTransfer.files, function (item) {file.push(item)}, false)// Array.from(e.dataTransfer.files).forEach((item) => { file.push(item) })// 遍历对象 存入文件数组file.forEach(async (item) => {const base64 = await this.getBase64(item)this.getImageUrl(base64, item.name)})},async inputChange (e) {const base64 = await this.getBase64(e.target.files[0])this.getImageUrl(base64, e.target.files[0].name)},// 图片上传cdn 生成链接getImageUrl (base64, fileName) {const url = 'https://bird.ioliu.cn/v1?url=http://hn216.api.yesapi.cn'axios.post(url, {file: base64,s: 'App.CDN.UploadImgByBase64',app_key: '228290AC6E185D2121CD5878EDC4D010',file_name: fileName}).then((res) => {this.files.push({url: res.url,name: fileName,index: Math.random()})}).catch(() => {// 使用默认的const res = {url: 'https://dss0.bdstatic.com/70cFvHSh_Q1YnxGkpoWK1HF6hhy/it/u=191936283,2923048863&fm=26&gp=0.jpg'}this.files.push({url: res.url,name: fileName,index: Math.random()})})},// 图片转化成base64 便于上传cdn转成链接getBase64 (file) {return new Promise((resolve, reject) => {let reader = new FileReader()if (file) {// 将文件以Data URL形式读入页面let imgUrlBase64 = reader.readAsDataURL(file)reader.onload = function (e) {resolve(reader.result)}}})}}
}
</script><style scoped>
.image-uploader {margin: 20px;border: 3px dashed #fff;background: #2196F3;padding: 10px;text-align: center;color: #fff;border-radius: 10px;font-weight: 500;
}
.image-uploader.isDraging {background: #fff;border: 3px dashed #2196F3;color: #2196F3;
}
.real-btn {cursor: pointer;position: relative;padding: 10px 20px;background: #fff;border-radius: 10px;color: #2196F3;
}
.real-btn.isDraging-btn {background: #2196F3;color: #fff;
}
.hide-btn {width: 100%;height: 100%;top: 0;left: 0;position: absolute;opacity: 0;
}
.icon {width: 50px;height: 50px;
}
.file-list {display: flex;flex-wrap: wrap;margin-top: 10px;
}
.file-list img {width: 100%;
}
.list-item {width: 50%;
}
</style>

(1)可以判断一下上传的文件类型,通过type字段,然后做相应的处理

比如类型不正确,然后进行报错提示

(2)还可以拿到上传文件的大小,通过size字段

 

 


http://chatgpt.dhexx.cn/article/pyhdyOwA.shtml

相关文章

vue文件上传和下载

文件上传 这里使用elementui组件库的文件上传组件 1.手动上传&#xff08;文件选取后需点击确认上传&#xff09; action&#xff1a;上传地址auto-upload&#xff1a;是否在选取文件后立即进行上传&#xff0c;默认true手动上传要将其设置为falsebefore-upload &#xff1a…

windows修改文件后缀名(文件扩展名)

1.直接修改 打开我的电脑->查看->文件拓展名 勾上即可 before \qquad\qquad\qquad\qquad\qquad after \qquad\qquad 2.任何文本编辑器->另存为->保存类型选所有文件

Windows11修改文件后缀名的方法

Windows11修改文件后缀名的方法 最近买了一台新电脑&#xff1a;suface pro8 新电脑是真的香啊&#xff0c;但是目前发现一个问题&#xff0c;就是windows11的环境对文件后缀名的可修改性不太友好。 他的自定义是对文件后缀名也看不见的&#xff0c;通过一些设置可以查看到文件…

window10 系统下如何修改文件后缀

文章目录 需求&#xff1a;修改后缀&#xff08;方法一&#xff09;&#xff1a;1、打开-- 文件扩展名&#xff1a;2、重名了文件&#xff1a; 修改后缀&#xff08;方法二&#xff0c;新增&#xff09;1、代码修改过程&#xff08;很简单&#xff0c;拖入&#xff0c;写入文件…

matlab 实现批量修改文件后缀名 案例

实现目标描述&#xff1a;选择我有一个大文件&#xff0c;里面有许多子文件夹&#xff0c;子文件夹内都是csv格式的文件&#xff0c;我现在将这个大文件内所有子文件夹的.csv文件的后缀名改为.sps文件 %author foddcus FAFU %用法&#xff1a;批量修改文件后缀名 clear all src…

如何修改文件后缀

文章目录 1.搜索“文件资源管理器选项”2.打开我的电脑选项 1.搜索“文件资源管理器选项” 点击查看、取消选择“隐藏拓展名”2.打开我的电脑选项 wine打开文件夹资源管理器&#xff0c;点击查看&#xff0c;点击“文件拓展名”

WIN10 如何修改 文件后缀名 设置后缀名可修改

管理员权限下&#xff1a;打开任意一个文件夹---查看---选中文件扩展名&#xff1a;这时 文件的后缀名就显示出来了&#xff0c;单击文件 就可以修改后缀名了

python文件操作3--批量修改文件后缀名

1、引言 需要把.dat 格式 转化成 .txt格式 2、实现 # python批量更换后缀名 import os# 列出当前目录下所有的文件 files os.listdir(.) for filename in files:portion os.path.splitext(filename)# 如果后缀是.datif portion[1] ".dat": # 重新组合文件名和…

怎么修改html后缀名,在win7系统下如何修改文件后缀名?win7修改文件后缀名html方法...

在win7系统默认情况下&#xff0c;直接在文件后面加上“.扩展名”&#xff0c;相当于给文件命名&#xff0c;而不是直接修改文件类型的。那么在win7系统下如何修改文件后缀名?下面小编就为大家介绍win7修改文件后缀名html方法&#xff0c;一起来看看吧&#xff01; 方法/步骤 …

linux 批量修改文件后缀名

今天遇到的一个问题&#xff0c;要将一批jpg文件后缀名更改为png&#xff0c;凭感觉能用awk指令进行修改&#xff0c;就进行了尝试。 想到的思路是&#xff1a;先列举出文件名称&#xff0c;再用awk对文件名称进行处理分割&#xff0c;最后将后缀名进行修改。 首先列举出文件…

批量修改后缀名的方法,批量修改文件后缀名

批量修改后缀名的方法&#xff0c;批量修改文件后缀名&#xff01;文件的后缀名就是文件的拓展名&#xff0c;有些小伙伴在工作中经常需要修改文件后缀名&#xff0c;这是一个并不困难的电脑操作&#xff0c;我们只需要选中文件然后鼠标右击它&#xff0c;点击重命名&#xff0…

Windows系统批量修改文件后缀名/扩展名

查看文件 查看文件是否有扩展名&#xff0c;没有后缀名通过ctrlE打开计算机&#xff0c;找到“工具”—>“文件夹选项”—>“查看”&#xff0c;取消勾选“隐藏已知文件类型的扩展名”&#xff0c;然后就可以看到文件的扩展名。如果打开扩展名后还是没有显示扩展名&#…

windows下如果批量修改文件的后缀名

背景 电脑上有几十个mp4格式的视频学习资料&#xff0c;这些资料都学完了&#xff0c;打算把它安全的封存起来&#xff0c;最有效的封存方法是把名字修改了&#xff0c;而且后缀名mp4删掉或者改成一个不常见的后缀名。 刚开始我是一个一个的重命名&#xff0c;这样发现太麻烦了…

怎么批量修改文件后缀名?

怎么批量修改文件后缀名&#xff1f;什么是文件的后缀名&#xff0c;相信大家都应该知道吧&#xff0c;例如一张图片的名称是“1.jpg”&#xff0c;那么“.jpg”就是文件的后缀名。工作中有时候我们需要对文件后缀名进行修改&#xff08;这里不是格式转换&#xff09;&#xff…

Python 实用技巧 —— 批量修改文件后缀(类型)

批量修改文件后缀&#xff08;属性&#xff09; 1.1 读取目录并切分1.2 获取文件前后缀名1.3 文件重命名思路1.4 os.rename 实现重命名1.5 批量修改文件属性 思路&#xff1a; 读取目录下文件的类型(os.listdir("…"))分割文件名与文件类型&#xff0c;以 ‘点’ 为…

windows10批量修改文件后缀名

windows10批量修改文件后缀名 步骤 1. 在windows开始栏中打开命令提示符&#xff0c; 也可以用快捷键:winR ,输入cmd&#xff0c;回车 2. cd到你需要修改后缀名的文件夹目录下&#xff0c;输入命令:ren *.bat *.png 命令行的意思是 把所有bat文件修改成png文件

如何批量修改文件后缀名?

如何批量修改文件后缀名&#xff1f;文件的后缀名告诉了我们这个文件是什么文件&#xff0c;例如后缀名为docx的文件是word&#xff0c;后缀名为xlsx的文件是excel表格。在文件的使用过程中&#xff0c;我们也经常需要对文件的后缀名进行修改。电脑上修改文件后缀名的操作也比较…

bat之统一修改文件名后缀

调整文件后缀 注意&#xff1a;以下所有代码块都需要ANSI编码&#xff0c;新建txt输入相关代码&#xff0c;最后将txt改为bat&#xff0c;运行。 1、统一修改格式类型 &#xff08;1&#xff09;例子A&#xff1a;将后缀png改为gif 例子A实现方法&#xff1a; ren *.png *.g…

Python 批量修改文件后缀

文章目录 一、需求来源。二、解题思路总结 一、需求来源。 这个是我在学习视频的时候遇见的一个问题&#xff1a;该视频所用的笔记软件是为知笔记&#xff0c;它的笔记文件格式是.ziw&#xff0c;在这个过程中&#xff0c;我用为知笔记也不好打开&#xff0c;经过百度&#xf…

Win11文件类型怎么改?Win11修改文件后缀的方法

Win11文件类型怎么改&#xff1f;有时候我们想要打开电脑文件时&#xff0c;却发现文件打不开的情况&#xff0c;出现这一情况有可能是文件损坏&#xff0c;又或者是当前文件的格式不符合打开要求&#xff0c;对此我们可以试着修改文件的格式类型&#xff0c;那么应该如何操作呢…