element-ui+vue2实现粘贴上传

element-ui+vue2实现粘贴上传

<style scoped lang="scss">.img-upload{position: relative;display: inline-block;margin-right: 9px;}.image {width: 100px;height: 100px;margin-right: 9px;}.image:last-child{margin-right: 0;}.img-upload .el-upload--picture-card,.img-upload .el-upload-list__item{height: 100px;width: 100px;line-height: 100px;}.img-upload .el-icon-close-tip{display: none !important;}.img-upload .el-upload-list__item-status-label{display: none !important;}.hide .el-upload--picture-card {display: none;}.img-upload-title-required:before {content: '*';color: #F56C6C;margin-right: 4px;}.el-upload__tip{color: red;}.hide.el-upload-list .el-upload-list__item.is-focus {border: 2px solid red; /* 设置选中图片的红色边框样式 */}
</style><script async defer>var uploadMultiImage  = {template:`<div class="img-upload"><div v-if="!detail"><el-uploadref="upload":class="{hide:hideUpload}":action="action"list-type="picture-card":limit="limit":file-list="fileList":multiple="multiple":on-success="uploadSuccess":on-exceed="uploadExceed":on-change="uploadChange":on-remove="uploadRemove":on-preview="handlePictureCardPreview"@paste.native="handlePaste"><i class="el-icon-plus"></i></el-upload><div :class="required?'img-upload-title img-upload-title-required':'img-upload-title'">{{title}}</div><div v-if="tip" slot="tip" class="el-upload__tip">{{tip}}</div></div><div v-else><div v-if="imageList" ><el-image v-for="(item,index) in fileList"  :key=item.url :src="item.url+'?w=80&h=80'" class="image" :preview-src-list="[item.url]" @click.stop="handleClickItem"></el-image></div></div><el-dialog :visible.sync="dialogVisible"><img width="100%" :src="dialogImageUrl" alt=""></el-dialog></div>`,props: {urls:{type: [String, Array],default(){return []}},action:{type:String,default:'/v1/api/index/upload'},detail:{type:Boolean,default:false},multiple:{type:Boolean,default:false},title:{type:String,default:''},limit:{type:Number,default:1},required:{type:Boolean,default:false},tip:{type:String,default:''},},model:{prop:'urls',event:'valChange'},created(){},watch:{urls(val){this.imageList = val},},data(){return {fileList: this.pathUrls(this.urls),imageList: this.urls,hideUpload: this.isHideUpload(this.urls),dialogImageUrl: '',dialogVisible: false}},mounted() {},computed:{},methods:{/*** 监听粘贴操作*/handlePaste(e) {var clipboardData = e.clipboardData; // IEif (!clipboardData) {//chromeclipboardData = e.originalEvent.clipboardData;}var items='';items = (e.clipboardData || window.clipboardData).items;let file = null;if (!items || items.length === 0) {this.$message.error('当前浏览器不支持粘贴本地图片,请打开图片复制后再粘贴!');return;}// 搜索剪切板itemsfor (let i = 0; i < items.length; i++) {// 限制上传文件类型if (items[i].type.indexOf('image') !== -1) {file = items[i].getAsFile();break;}}// 对复制黏贴的类型进行判断,若是非文件类型,比如复制黏贴的文字,则不会调用上传文件的函数if(file){// console.log(file)// // 生成一个本地的URL用于预览// const url = URL.createObjectURL(file);// console.log(url)// 添加到fileList中,这里示意性地只存放url,实际应根据需求进行适当处理//this.fileList.push({ url: url });let formData = new FormData();formData.append('file', file, 'pasted_image.png'); // 'file' 是后端接口接收文件的字段名,'pasted_image.png' 是文件名console.log(formData);// 上传文件到服务器this.uploadPastedImage(formData);}},uploadPastedImage(formData) {fetch(this.action, {method: 'POST',body: formData}).then(response => response.json()).then(data => {if (data.code) {console.log(data);const newFile = {name: 'pasted_image.png',url: data.domain + '/' + data.data[0],uid: Date.now(), // 确保每个文件有唯一的uidstatus: 'success' // 设置文件状态为成功};//this.fileList = this.fileList.filter(file => !file.url.startsWith('blob:'));this.fileList.push(newFile);this.valChange();} else {this.$message.error('上传失败,请稍后重试');}}).catch(error => {this.$message.error('网络错误,请稍后重试');console.error('Error:', error);});},pathUrls(urls){let fileList = []if(urls.length>0){urls.forEach(function(v) {if(!v.includes('http')){fileList.push({'name': v,'url':'http://image.spocoo.com/' + v,})}else {fileList.push({'name': v,'url': v,})}});}return fileList},nameUrls(fileList){let urls = []fileList.forEach(function(v) {if(v.response){urls.push(v.response.data[0])}else{urls.push(v.url)}});return urls},isHideUpload(urls){return urls.length >= this.limit;},uploadSuccess(res,file, fileList){if (res.code){this.fileList = fileListthis.valChange()}else{layer.msg('网络走丢了,请稍后重试上传哦')}},uploadExceed(){layer.msg(this.title+'最多可以上传'+this.limit+'张图片')},uploadChange(file, fileList) {this.hideUpload = fileList.length >= this.limit;},uploadRemove(file, fileList) {this.fileList.splice(this.fileList.findIndex(e => e.url === file.url), 1)this.hideUpload = fileList.length >= this.limit;this.valChange()},//预览handlePictureCardPreview(file) {this.dialogImageUrl = file.url;this.dialogVisible = true;},valChange(){this.$emit('valChange',this.nameUrls(this.fileList))},handleClickItem(){this.$nextTick(()=>{// 获取遮罩层domlet domImageMask = document.querySelector(".el-image-viewer__mask");if (!domImageMask) {return;}domImageMask.addEventListener("click", () => {// 点击遮罩层时调用关闭按钮的 click 事件document.querySelector(".el-image-viewer__close").click();});})}}}
</script>

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/877282.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

又一新AI搜索工具,OpenAI 推出新的搜索方式 SearchGPT

系列文章目录 每天推荐AI工具系列文章回顾&#xff1a; 选择 haiyi海艺图像生成、LoRA、模型的使用和训练网站 tusiart吐司艺术图像生成、LoRA 模型的使用和训练网站 解锁AI创造力的无限可能&#xff1a;探索Vivago.ai的革命性功能 文章目录 系列文章目录前言一、SearchGPT…

<数据集>手机识别数据集<目标检测>

数据集格式&#xff1a;VOCYOLO格式 图片数量&#xff1a;16172张 标注数量(xml文件个数)&#xff1a;16172 标注数量(txt文件个数)&#xff1a;16172 标注类别数&#xff1a;1 标注类别名称&#xff1a;[Phone] 使用标注工具&#xff1a;labelImg 标注规则&#xff1a;…

什么是线程安全?

什么是线程安全&#xff1f; 为什么需要线程安全&#xff1f;如何实现线程安全&#xff1f;1. 排队干活2. 自己带工具3. 用现成的安全工具 4、示例5、总结 &#x1f496;The Begin&#x1f496;点点关注&#xff0c;收藏不迷路&#x1f496; 在编程里&#xff0c;特别是当程序能…

推荐一款专注批量推送消息的轻量工具,支持主流平台的消息推送,简单、高效、低成本(附源码)

前言 在数字化时代&#xff0c;企业和个人面临着日益增长的消息推送需求。然而&#xff0c;现有的推送处理方案往往存在一些挑战和不足&#xff0c;如cao作复杂、成本高昂、缺乏灵活性等。这些问题不仅影响了推送效率&#xff0c;也增加了用户的负担。此外&#xff0c;随着工作…

华为od 100问 持续分享10-华为OD的面试流程细说

我是一名软件开发培训机构老师&#xff0c;我的学生已经有上百人通过了华为OD机试&#xff0c;学生们每次考完试&#xff0c;会把题目拿出来一起交流分享。 重要&#xff1a;2024年5月份开始&#xff0c;考的都是OD统一考试&#xff08;D卷&#xff09;&#xff0c;题库已经整…

Matlab编程资源库(16)数值微分

一、数值差分与差商 在Matlab中&#xff0c;数值差分与差商是数值分析中常用的概念&#xff0c;尤其在求解微分方程、插值、逼近等领域有广泛应用。下面简要介绍这两个概念及其在Matlab中的实现。 数值差分 数值差分是微分运算的离散化形式&#xff0c;用于近似求解导数。给定…

平台数据脱敏方案

在目前大环境下&#xff0c;这几年做事业政府单位的信息化项目&#xff0c;都特别强调安全&#xff0c;原因大伙都清楚。 安全包含两块&#xff0c;一是框架组件安全&#xff0c;二是业务信息安全。 框架组件安全一般就是漏洞修复&#xff0c;组件升级到对应没有漏洞的版本。 业…

数据结构【有头双向链表】

目录 实现双向链表 双向链表数据 创建双向链表 初始化双向链表创建&#xff08;哨兵位&#xff09; 尾插 打印双向链表 头插 布尔类型 尾删 头删 查询 指定位置后插入 指定位置删除数据 销毁 顺序表和链表的分析 代码 list.h list.c test.c 注意&#xff1a…

清华学姐熬夜肝了15天的软件测试面试题出炉(附答案)建议收藏!

一、Web自动化测试 1.Selenium中hidden或者是display &#xff1d; none的元素是否可以定位到&#xff1f; 不能,可以写JavaScript将标签中的hidden先改为0&#xff0c;再定位元素 2.Selenium中如何保证操作元素的成功率&#xff1f;也就是说如何保证我点击的元素一定是可以…

C:图案打印

引言 本篇文章讲了一些常见的图形编程题&#xff0c;并总结了一些规律。 1、打印空心正方形 1.1 代码展示&#xff1a; #include<stdio.h> int main() {int a 0;//边长初始化scanf("%d", &a);//输入边长的值{int i 0;for (i 0; i < a; i)//控制行…

知识图谱增强的RAG(KG-RAG)详细解析

转自&#xff1a;知识图谱科技 这是一个与任务无关的框架&#xff0c;它将知识图谱&#xff08;KG&#xff09;的显性知识与大型语言模型&#xff08;LLM&#xff09;的隐含知识结合起来。这是该工作的arXiv预印本 https://arxiv.org/abs/2311.17330 。 我们在这里利用一个名为…

自定义表格_可拖拽排序

在做后台管理系统的时候&#xff0c;经常需要表格里面的每行排序&#xff0c;自定义可拖拽表格&#xff0c;更改样式方便。 一、实现效果 进行拖拽演示&#xff1a; 可拖拽排序表格 无滚动条样式&#xff1a; 有滚动条样式&#xff1a; 二、代码 使用reactscssts,实现页面。 …

Linux(CentOS)ftp服务搭建

ftp服务器搭建 1. 下载ftp服务2. 查找ftp配置文件3. 查看配置文件信息4. Windows连接ftp服务1&#xff09;使用文件资源管理器连接2&#xff09;使用FlashFXP工具&#xff0c;比文件资源管理器好用&#xff0c;强烈推荐 5. Linux连接 1. 下载ftp服务 yum install -y vsftpd2. …

Docsify:快速用Markdown文档搭建网站的利器

Github官方地址&#xff1a;Docsify 什么是Docsify&#xff1f; 对于经常写博客的人来说&#xff0c;markdown大家都不陌生。今天介绍一个在最近需求中碰到的软件Docsify&#xff0c;通过它能够将Markdown直接转换为网页。话不多说&#xff0c;下面直接介绍它的快速用法。 D…

Apache、nginx

一、Web 1、概述 Web&#xff1a;为⽤户提供的⼀种在互联⽹上浏览信息的服务&#xff0c;Web 服务是动态的、可交互的、跨平台的和图形化的。 Web 服务为⽤户提供各种互联⽹服务&#xff0c;这些服务包括信息浏览服务&#xff0c;以及各种交互式服务&#xff0c;包括聊天、购物…

fastapi教程(五):中间件

一&#xff0c;什么是中间件 中间件是一种软件组件&#xff0c;它在请求到达应用程序处理程序之前和/或响应发送回客户端之前执行操作。 请求从客户端发出。 请求首先经过Middleware 1。 然后经过Middleware 2。 请求到达FastAPI路由处理器。 响应从路由处理器返回。 响应经过…

如何通过 CloudCanal 实现从 Kafka 到 AutoMQ 的数据迁移

01 引言 随着大数据技术的飞速发展&#xff0c;Apache Kafka 作为一种高吞吐量、低延迟的分布式消息系统&#xff0c;已经成为企业实时数据处理的核心组件。然而&#xff0c;随着业务的扩展和技术的发展&#xff0c;企业面临着不断增加的存储成本和运维复杂性问题。为了更好地…

《LeetCode热题100》---<双指针篇四道>

本篇博客讲解LeetCode热题100道双指针篇中的 第一道&#xff1a;移动零&#xff08;简单&#xff09; 第二道&#xff1a;盛最多水的容器&#xff08;中等&#xff09; 第一道&#xff1a;移动零&#xff08;简单&#xff09; class Solution {public void moveZeroes(int[] nu…

基于CentOS Stream 9平台安装JDK17.0.12

官方&#xff1a; https://www.oracle.com/java/technologies/downloads/#java17 1. 下载&#xff1a; https://download.oracle.com/java/17/latest/jdk-17_linux-x64_bin.tar.gz 2. 存放目录 mkdir /usr/local/javacd /usr/local/java3. 解压 tar -zxvf jdk-17_linux-x64_…

除了GPT,还有哪些好用的AI工具?

最强AI视频生成&#xff1a;小说文案智能分镜智能识别角色和场景批量Ai绘图自动配音添加音乐一键合成视频百万播放量https://aitools.jurilu.com/ 多得很&#xff0c;这20个免费的国产AI工具&#xff0c;打工人必备&#xff0c;除了比chatGPT好用&#xff0c;甚至还可以用来变现…