使用Element UI实现Ctrl + V图片上传功能
创作时间:
作者:
@小白创作中心
使用Element UI实现Ctrl + V图片上传功能
引用
51CTO
1.
https://blog.51cto.com/miaow/12515706
本文将介绍如何在Element UI的拖拽上传组件中实现Ctrl + V图片上传功能。通过监听键盘事件,我们可以捕获粘贴板中的图片数据,并将其转换为File对象进行上传。文章将分两个版本逐步实现这一功能:第一个版本实现获取粘贴板中的图片文件,第二个版本则进一步实现在上传过程中展示压缩图片的功能。
版本V1:实现获取粘贴板中的文件
注意,本案例需要在你已经安装了Element UI并在项目中正确配置的情况下进行。第一个版本仅适合上传jpeg和png的图片。
创建拖拽上传组件
假设你已经有一个基本的拖拽上传组件,我们可以在此基础上添加Ctrl + V功能。
监听粘贴事件
我们需要在页面中监听paste事件,当用户按下Ctrl + V时,捕获粘贴板中的图片数据。
处理粘贴事件
在捕获到图片数据后,将其转换为File对象,并调用上传方法。
代码如下:
<template>
<div>
<el-upload
drag
action="https://jsonplaceholder.typicode.com/posts/"
:on-preview="handlePreview"
:on-remove="handleRemove"
:before-upload="beforeUpload"
multiple
ref="upload"
>
<i class="el-icon-upload"></i>
<div class="el-upload__text">将文件拖到此处,或<em>点击上传</em></div>
<div class="el-upload__tip" slot="tip">只能上传jpg/png文件,且不超过500kb</div>
</el-upload>
</div>
</template>
<script>
import { Upload } from 'element-ui';
export default {
name: 'DragUpload',
methods: {
handlePaste(event) {
// 捕获粘贴事件
const items = event.clipboardData.items;
for (let i = 0; i < items.length; i++) {
if (items[i].type.indexOf('image') !== -1) {
// 获取图片文件
const file = items[i].getAsFile();
this.handleFile(file);
break;
}
}
},
handleFile(file) {
// 将文件添加到上传队列
this.$refs.upload.handleStart(file);
this.$refs.upload.submit();
},
handlePreview(file) {
console.log('Preview:', file);
},
handleRemove(file, fileList) {
console.log('Remove:', file, fileList);
},
beforeUpload(file) {
const isJPGorPNG = file.type === 'image/jpeg' || file.type === 'image/png';
const isLt500K = file.size / 1024 < 500;
if (!isJPGorPNG) {
this.$message.error('只能上传 JPG/PNG 格式的图片!');
}
if (!isLt500K) {
this.$message.error('图片大小不能超过 500KB!');
}
return isJPGorPNG && isLt500K;
}
},
mounted() {
// 监听粘贴事件
document.addEventListener('paste', this.handlePaste);
},
beforeDestroy() {
// 移除粘贴事件监听
document.removeEventListener('paste', this.handlePaste);
}
};
</script>
- HTML部分:使用el-upload组件创建一个拖拽上传区域。
- JavaScript部分:
- handlePaste方法:捕获粘贴事件,检查粘贴板中的数据是否为图片文件,如果是,则调用handleFile方法。
- handleFile方法:将图片文件添加到上传队列,并提交上传。
- mounted生命周期钩子:添加粘贴事件监听器。
- beforeDestroy生命周期钩子:移除粘贴事件监听器,防止内存泄漏。
随便截图一张,我们这个时候ctrl + v就可以发现他可以获取我们粘贴板中的文件。
我们到这一步发现,图片网页是获取到。这个时候你在跟着你的业务,传递相关参数,这第V1版本就可以用了。
第二版本V2:可以直接在粘贴的过程在下面以压缩图片的形式展示图片
<template>
<div>
<el-upload
drag
:action="uploadFileUrl"
:on-preview="handlePreview"
:on-remove="handleRemove"
:before-upload="beforeUpload"
:on-success="handleSuccess"
multiple
ref="upload"
:file-list="fileList"
>
<i class="el-icon-upload"></i>
<div class="el-upload__text">将文件拖到此处,或<em>点击上传</em></div>
<div class="el-upload__tip" slot="tip">只能上传jpg/png文件,且不超过500kb</div>
</el-upload>
<!-- 显示上传后的文件 -->
<div v-for="(file, index) in fileList" :key="index" class="uploaded-file">
<div v-if="isImage(file.name)">
<img :src="file.url" alt="Uploaded Image" class="uploaded-image" />
<el-button type="text" @click="removeFile(index)">移除</el-button>
</div>
<div v-else>
<span>{{ file.name }}</span>
<el-button type="text" @click="removeFile(index)">移除</el-button>
</div>
</div>
</div>
</template>
<script>
import { Upload } from 'element-ui';
export default {
name: 'DragUpload',
data() {
return {
fileList: []
};
},
methods: {
handlePaste(event) {
const items = event.clipboardData.items;
for (let i = 0; i < items.length; i++) {
if (items[i].type.indexOf('image') !== -1) {
const file = items[i].getAsFile();
this.handleFile(file);
break;
}
}
},
handleFile(file) {
const reader = new FileReader();
reader.onload = (e) => {
this.fileList.push({
name: file.name,
url: e.target.result
});
};
reader.readAsDataURL(file);
this.$refs.upload.handleStart(file);
this.$refs.upload.submit();
},
handlePreview(file) {
console.log('Preview:', file);
},
handleRemove(file, fileList) {
this.fileList = fileList;
},
beforeUpload(file) {
const isJPGorPNG = file.type === 'image/jpeg' || file.type === 'image/png';
const isLt500K = file.size / 1024 < 500;
if (!isJPGorPNG) {
this.$message.error('只能上传 JPG/PNG 格式的图片!');
}
if (!isLt500K) {
this.$message.error('图片大小不能超过 500KB!');
}
return isJPGorPNG && isLt500K;
},
handleSuccess(response, file, fileList) {
// 更新 fileList
this.fileList = fileList.map(f => ({
name: f.name,
url: f.url || f.response.url // 假设服务器返回的响应中有 url 字段
}));
},
removeFile(index) {
this.fileList.splice(index, 1);
},
isImage(fileName) {
return fileName.toLowerCase().endsWith('.jpg') || fileName.toLowerCase().endsWith('.png');
}
},
mounted() {
document.addEventListener('paste', this.handlePaste);
},
beforeDestroy() {
document.removeEventListener('paste', this.handlePaste);
}
};
</script>
<style scoped>
.uploaded-file {
margin-top: 10px;
display: flex;
align-items: center;
}
.uploaded-image {
max-width: 100px;
max-height: 100px;
margin-right: 10px;
}
</style>
如图所示。Ctrl + V就实现到了这一步。这里有问题,那就是你看一下,点击上传后的图片是否会显示出来呢?
热门推荐
探索海南之美:海口更受欢迎旅游景点全方位指南
四九天的保暖秘籍
数九寒天:从冬至到春来的八十一天
范曾夫妇捐赠180万艺术作品 助力“一老一小”帮扶项目
陕北红枣馍馍完美制作教程
陕北红枣教你做出美味蒸枣馍馍
温居之礼,寓意深远:如何挑选一份承载祝福的乔迁礼物
乔迁新居送什么礼物
乔迁之喜送什么礼物?老话说“搬家送三样,家旺人也旺”,是啥
拍摄人像如何走出虚化的怪圈?除了虚化,还能从哪些角度来拍摄人像
什么是变焦镜头?它与定焦镜头有哪些区别?
什么是变焦镜头?它与定焦镜头有哪些区别?
婉容故居帽儿胡同35和37号
佳能眼控对焦技术:从经典胶片到智能无反的创新之路
炸土豆条的神仙做法,外酥里嫩秒杀外卖!
前蹄or后蹄?冬季煲汤秘籍大揭秘!
猪蹄:中国传统美食的营养密码
冷冻猪蹄选购指南:如何辨别安全性?
2025武侯祠大庙会门票价格出炉!40元带你畅游三国文化盛宴
2024成都武侯祠大庙会:三国元宇宙里的科技年味
自制虾滑:健康美味的餐桌新宠
自制虾滑:简单几步,打造健康美味
王莽新朝:中国历史上唯一的王姓统一王朝
范曾夫妇缘梦基金公益发表会成功启幕,180万元善款助力“一老一小”帮扶工作
告别健身房,7个徒手动作,在家只需10分钟,塑造你的腹部线条
珠宝管理:探究影响珠宝店生意的十大原因
教育部推动高校专业改革,破解就业难题
冬天的第一款草莓蛋糕,烘焙新手必学!
马长生教授解读:房颤消融术后抗凝策略
房颤消融术后恢复全攻略:从饮食到运动的全方位指导