element用户上传头像组件带大图预览,和删除功能

element 用户上传组件不支持大图预览,拿组件的简单修改一些,发表上来主要是记一下,以后可以用

效果图

<template><div class="flex-img"><div class="el-upload-list el-upload-list--picture-card" v-show="hideShow"><div class="el-upload-list__item is-success"><img class="flex-img__image" :src="imageUrl"><label class="el-upload-list__item-status-label"><i class="el-icon-upload-success el-icon-check"></i></label><span class="el-upload-list__item-actions" ><span@click="handlePictureCardPreview()"><i class="el-icon-zoom-in"></i></span><span class="el-upload-list__item-delete" v-show="disabledBoolean ? false:true"><i class="el-icon-delete" @click.stop="handleRemove()"></i></span></span></div></div><el-uploadclass="image-uploader":show-file-list="false":headers="headers"action="/api/blade-resource/oss/endpoint/put-file":on-success="handleAvatarSuccess":before-upload="beforeUpload"v-show="!hideShow"><i class="el-icon-plus"></i></el-upload><el-dialog :visible.sync="dialogVisible"     append-to-body><img width="100%" :src="imageUrl" alt=""></el-dialog></div>
</template><script>import {getToken} from "@/util/auth";export default {name: "uploadImage.vue",data() {return {file: this.imageUrl ? this.imageUrl : '',headers:"", //上传地址imageForm:"",//给父组件传值dialogVisible: false,//控制大图预览};},props:{imageUrl:{//父组件传值过来照片回显type:String,dispatch() {return "";}},disabledBoolean:{//父组件传过来是编辑,还是查看type: Boolean,default() {return false;}},},watch:{imageUrl(value) {this.file = value},imageForm(value) {//当照片地址改变的时候,给父组件传值const list = value;this.$emit('updateImage', list);}},computed: {hideShow() {//当图片多于一张的时候,就隐藏上传框return this.file === '' ? false : true}},methods: {handlePictureCardPreview() {this.dialogVisible = true;},beforeUpload(file) {const imageSize = file.size / 1024 / 1024 < 1;//上传图片大小不超过1Mif (!imageSize) {this.$message.error('上传封面大小不能超过 1MB!');}return imageSize;},//删除照片是清空所有handleRemove() {this.file = '';this.imageUrl="";this.imageForm="";},handleAvatarSuccess(res, file) {this.imageUrl =  URL.createObjectURL(file.raw);this.imageForm = res.data.name;},}
}
</script><style scoped>
.flex-img {display: flex;
}
.image-uploader {background-color: #fbfdff;border: 1px dashed #c0ccda;border-radius: 6px;-webkit-box-sizing: border-box;box-sizing: border-box;width: 148px;height: auto;cursor: pointer;line-height: 146px;vertical-align: top;text-align: center
}.image-uploader {font-size: 28px;color: #8c939d;
}.image-uploader .el-upload:hover {border-color: #409EFF;
}.flex-img__image {width: 146px;height: auto;border-radius: 6px;
}
</style><style>
.avatar-uploader .el-upload {border: 1px dashed #d9d9d9;border-radius: 6px;cursor: pointer;position: relative;overflow: hidden;
}
.avatar-uploader .el-upload:hover {border-color: #409EFF;
}
.avatar-uploader-icon {font-size: 28px;color: #8c939d;width: 178px;height: 178px;line-height: 178px;text-align: center;
}
.avatar {width: 178px;height: 178px;display: block;
}
</style>

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

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

相关文章

word从零基础到高手【办公】

第1课 - word基础操作快速入门第2课 - 让你效率10倍提升的快捷操作第3课 - word排版快速入门第4课 - 排版实战案例讲解第5课 - 搞定论文排版全过程第6课 - 让你的word更强大的神技第7课 - 提高工作效率必备的批量操作 资料截图如下: 发送: "word办公" 获取提取码

动态规划-入门理解

一、什么情况可以使用动态规划 动态规划 最优子结构 重叠子问题 转移方程 最优子结构&#xff1a;保证能从局部解推出全局解&#xff0c;也就是保证能够写出转移方程 重叠子问题&#xff1a;说明暴力解法太耗时&#xff0c;我们可以使用动态规划进行优化 转移方程&#xff…

基于GAN的图像补全实战

数据与代码地址见文末 论文地址:http://iizuka.cs.tsukuba.ac.jp/projects/completion/data/completion_sig2017.pdf 1.概述 图像补全,即补全图像中的覆盖和缺失部分, 网络整体结构如下图所示,整体网络结构还是采取GAN,对于生成器,网络结构采取Unet的形式,首先使用卷积…

深入浅出 -- 系统架构之负载均衡Nginx跨域配置

一、Nginx跨域配置 跨域问题在之前的单体架构开发中&#xff0c;其实是比较少见的问题&#xff0c;除非是需要接入第三方SDK时&#xff0c;才需要处理此问题。但随着现在前后端分离、分布式架构的流行&#xff0c;跨域问题也成为了每个Java开发必须要懂得解决的一个问题。 跨域…

rac数据库默认网关不通导致集群异常

集群CSSD进程reconfiguration完成&#xff0c;显示2个节点都在线。但ora.net1.network服务启动失败&#xff0c;且有依赖关系的资源随后启动失败并且已经达到上限。 查看两个节点的网络信息&#xff0c;发现两个节点的默认网关是不一致的。 修改故障节点网关 在RAC中&#xff0…

基于springboot+vue+Mysql的职称评审管理系统

开发语言&#xff1a;Java框架&#xff1a;springbootJDK版本&#xff1a;JDK1.8服务器&#xff1a;tomcat7数据库&#xff1a;mysql 5.7&#xff08;一定要5.7版本&#xff09;数据库工具&#xff1a;Navicat11开发软件&#xff1a;eclipse/myeclipse/ideaMaven包&#xff1a;…

在线人数统计功能怎么实现?

一、前言 大家好&#xff01;我是sum墨&#xff0c;一个一线的底层码农&#xff0c;平时喜欢研究和思考一些技术相关的问题并整理成文&#xff0c;限于本人水平&#xff0c;如果文章和代码有表述不当之处&#xff0c;还请不吝赐教。 在线人数统计这个功能相信大家一眼就明白是…

基于奇异值分解(Singular Value Decomposition,SVD)的信号去噪算法

01.基于奇异值分解(SVD)去噪原理 奇异值分解&#xff08;Singular Value Decomposition, SVD&#xff09;是线性代数中一种重要的矩阵分解方法&#xff0c;它可以用于信号处理、图像去噪、数据压缩等多种应用。在图像去噪的过程中&#xff0c;SVD可以用来分离图像中的信号和噪…

Transformer详解和知识点总结

目录 1. 注意力机制1.1 注意力评分函数1.2 多头注意力&#xff08;Multi-head self-attention&#xff09; 2. Layer norm3. 模型结构4. Attention在Transformer中三种形式的应用 论文&#xff1a;https://arxiv.org/abs/1706.03762 李沐B站视频&#xff1a;https://www.bilibi…

SpringBoot Starter子模块下无法生成spring-configuration-metadata.json文件

一.SpringBoot Starter的作用 Starter的机制极大的方便了业务系统接入相关能力&#xff0c;它有一个非常友好的能力就是引入starter后&#xff0c;在配置相关的配置项时&#xff0c;能自动提示&#xff0c;极大的提升了使用的友好度。 二.遇到的问题 我在为Juggle开发系统star…

【图论】链式前向星实现图的BFS搜索

&#x1f4ab;【图论】链式前向星–BFS宽搜遍历 &#x1f44f;宽搜背景和实现的功能 输入: n m n:结点数量m:边的数量 输出:到达结点编号为n的最短路径, 每条路长度为1(宽度搜索的前前提条件) &#x1f914;思路&#xff1a; 采用链式前向星存图数组模拟队列的方法只要队列不…

[C++/Linux] Linux线程详解

目录 一.什么是线程&#xff1f; 并发&#xff08;Concurrency&#xff09; 并行&#xff08;Parallelism&#xff09; 1.1 线程的概念 1.2 线程的基本函数 1.3 线程的基本使用例子&#xff1a; 二.线程的属性 2.1线程属性使用例子 三.线程互斥 3.1互斥锁 3.2互斥锁常用函…

CLI举例:上下行连接路由器(路由引流)

CLI举例&#xff1a;上下行连接路由器&#xff08;路由引流&#xff09; 介绍了集群设备&#xff0c;上下行连接路由器的配置举例。 组网需求 如图1所示&#xff0c;上行网络使用BGP&#xff0c;下行网络使用OSPF&#xff0c;多数据中心统一通过路由器R4接入Internet。 希望…

solidworks卸载不干净怎么办?

当Solidworks卸载不干净时&#xff0c;您可以尝试以下方法来彻底清理卸载残留&#xff1a; 手动删除残留文件和注册表项&#xff1a; • 卸载程序&#xff1a;首先通过控制面板的“卸载或更改程序”功能尝试卸载Solidworks。 • 删除残留文件&#xff1a;在硬盘上找到Solidw…

数据结构之堆练习题及PriorityQueue深入讲解!

题外话 上午学了一些JavaEE初阶知识,下午继续复习数据结构内容 正题 本篇内容把堆的练习题做一下 第一题 1.下列关键字序列为堆的是:( A ) A: 100,60,70,50,32,65 B: 60,70,65,50,32,100 C: 65,100,70,32,50,60 D: 70,65,100,32,50,60 E: 32,50,100,70,65,60 …

HarmonyOS 开发-多模态页面转场动效实现案例

介绍 本示例介绍多模态页面转场动效实现&#xff1a;通过半模态转场实现半模态登录界面&#xff0c;通过配置NavDestinationMode类型为DIALOG&#xff0c;实现半模态的背景为透明&#xff0c;再与全屏模态和组件转场结合实现多模态组合登录场景&#xff0c;其中手机验证码登录…

第四次面试总结 — 嘉和智能 - 全栈开发

&#x1f9f8;欢迎来到dream_ready的博客&#xff0c;&#x1f4dc;相信您对专栏 “本人真实面经” 很感兴趣o (ˉ▽ˉ&#xff1b;) 专栏 —— 本人真实面经&#xff0c;更多真实面试经验&#xff0c;中大厂面试总结等您挖掘 目录 总结&#xff08;非详细&#xff09; 面试内…

【leetcode面试经典150题】39. 赎金信(C++)

【leetcode面试经典150题】专栏系列将为准备暑期实习生以及秋招的同学们提高在面试时的经典面试算法题的思路和想法。本专栏将以一题多解和精简算法思路为主&#xff0c;题解使用C语言。&#xff08;若有使用其他语言的同学也可了解题解思路&#xff0c;本质上语法内容一致&…

c# InvokeRequested delegate解决线程访问界面

说明 界面操作的代码应该写在界面&#xff08;Form/Dialog&#xff09;里 方法定义 private void Method1(string s) {...... }delegate定义 private delegate void Method1Delegate(string s);界面调用代码 private void op(){string sText"hello";if (this.In…

集合框架(数组,Arrays.sort,list,map,set,stack,queue)蓝桥杯习题

前言(基本知识) List集合 有序&#xff0c;接口&#xff0c; List<引用数据类型> listnew ArrayList<>(); 方法&#xff1a; add() size() get()//索引index从0开始&#xff0c;返回对应的值 isEmpty()判断是否包含该元素,不包含返回true&#xff0c;包含返…