关于实现微信截图粘贴实现图片上传

入局了vue3+ts的坑

在实现了粘贴获取到文件elementPlus没法调用组件自动上传

一开始考虑使用 image-clipboard这个插件,但是我使用安装不到我就放弃了

arduino 复制代码
npm install image-clipboard --save

上述得找源或者使用

arduino 复制代码
bower install image-clipboard

当然对我来说肯定放弃呀!!!!!!

那就是用window来检测做处理了

ini 复制代码
const handlePaste = (event: ClipboardEvent) => {
	const items = event.clipboardData?.items;
	if (items) {
		for (let i = 0; i < items.length; i++) {
			const item = items[i];
			if (item.type.indexOf('image') !== -1) {
				const blob = item.getAsFile();
				if (blob) {
					// 将粘贴的图片添加到文件列表中
					// fileList.value.push({
					// 	name: 'pasted-image.png', // 文件名
					// 	raw: blob, // 文件对象
					// 	url: URL.createObjectURL(blob), // 图片预览链接
					// });
					// 可以在这里上传图片到服务器
					uploadImg(blob);
				}
			}
		}
	}
};

上述一开始是准备使用自带的组件上传,但是后面发现

通过ref调用submit()没有办法来实现上传,百思不得其解。

然后就先使用了另外的接口来实现图片的上传,但是这个问题一直烦恼着我,然后就去看了源码

然后打印一下我的文件信息

然后再看我的代码

当我默认没有status时候给我默认success了,那么也就导致我没法接下来的上传,但是我功能都实现了,以我的懒惰肯定不会再去改动一下,

php 复制代码
                        fileList.value.push({
						name: 'pasted-image.png', // 文件名
						raw: blob, // 文件对象
						url: URL.createObjectURL(blob), // 图片预览链接
                                                status:'ready'
					          });

这样在使用ref就可以实现submit();

踩坑之路从未停止

相关推荐
0思必得04 分钟前
[Web自动化] Selenium浏览器对象属性
前端·python·selenium·自动化·web自动化
小二·9 分钟前
Python Web 开发进阶实战:边缘智能网关 —— 在 Flask + Vue 中构建轻量级 IoT 边缘计算平台
前端·python·flask
是毛毛吧13 分钟前
GitHub热榜----前端已死?AionUi 横空出世:首个开源“生成式UI”框架,让 AI 在运行时“手搓”界面
前端·开源·github
斯普信专业组16 分钟前
ReAct Agent 解析:从理论到实践的高效推理框架
前端·react.js·前端框架
徐同保17 分钟前
开发onlyoffice插件,功能是选择文本后立即通知父页面
开发语言·前端·javascript
23124_8022 分钟前
Base64多层嵌套解码
前端·javascript·数据库
程序员张335 分钟前
Element Plus SCSS 变量覆盖用法
vue.js·前端框架·element-plus
啥都不懂的小小白37 分钟前
Vue Ajax与状态管理完全指南:从数据请求到全局状态控制
vue.js·ajax·vuex·插槽系统
多看书少吃饭37 分钟前
文件预览的正确做法:从第三方依赖到企业级自建方案(Vue + Java 实战)
java·前端·vue.js
菜鸟很沉37 分钟前
Vue3 + Element Plus 实现大文件分片上传组件(支持秒传、断点续传)
javascript·vue.js