vue3 el-upload單張圖片回顯、編輯、刪除功能實(shí)現(xiàn)
vue3 el-upload單張圖片回顯、編輯、刪除功能

圖片回顯時(shí)隱藏上傳區(qū)域,鼠標(biāo)懸浮顯示遮罩層進(jìn)行編輯、刪除操作,刪除圖片后顯示上傳區(qū)域
vue部分:
①el-upload沒(méi)有限制上傳文件數(shù)量,如果limit=1,那么點(diǎn)擊編輯時(shí)不會(huì)觸發(fā)on-change事件,需要先清除當(dāng)前文件,頁(yè)面會(huì)出現(xiàn)上傳區(qū)域;
②刪除按鈕click.stop阻止事件冒泡,刪除后不會(huì)彈出上傳圖片窗口
<template>
<el-upload class="upload-demo" drag action="#" accept=".jpg,.png" :on-change="handleChange" :auto-upload="false"
ref="uploadRef" :show-file-list="false">
<!-- 圖片上傳框 -->
<div v-if="!fileList.length">
<el-icon class="el-icon--upload"><upload-filled /></el-icon>
<div class="el-upload__text">
Drop file here or <em>click to upload</em>
</div>
</div>
<!-- 回顯及遮罩層 -->
<div v-else>
<img :src="fileList[0].url" alt="">
<div class="mask">
<el-icon size="50">
<Edit />
</el-icon>
<el-icon size="50" @click.stop="handleDelete">
<Delete />
</el-icon>
</div>
</div>
<template #tip>
<div class="el-upload__tip tip">
jpg/png files with a size less than 500kb
</div>
</template>
</el-upload>
</template>ts部分:
<script setup lang="ts">
import { ref } from 'vue'
import type { UploadFile, UploadUserFile } from 'element-plus'
let fileList = ref<UploadUserFile[]>([])
const uploadRef = ref()
const handleChange = (file: UploadFile) => {
//如果上傳的圖片沒(méi)有url字段,手動(dòng)生成
if (!file.url) file.url = URL.createObjectURL(file.raw as any)
fileList.value[0] = file
}
const handleDelete = () => {
//刪除時(shí)清除所有已上傳圖片
uploadRef.value.clearFiles()
fileList.value = []
}
</script>樣式:
<style lang="scss" scoped>
:deep(.el-upload) {
height: 100%;
}
:deep(.el-upload-dragger) {
height: 100%;
padding: 10px;
display: flex;
flex-direction: column;
justify-content: center;
align-items: center;
box-sizing: border-box;
}
.upload-demo {
width: 300px;
height: 200px;
}
.tip {
color: red;
}
//遮罩層
.mask {
position: absolute;
top: 0;
left: 0;
width: 100%;
height: 100%;
background: rgba(100, 100, 100, 0.5);
color: #ffffff;
opacity: 0;
display: flex;
justify-content: center;
align-items: center;
&:hover {
opacity: 1;
}
.el-icon {
margin: 0 10px;
&:hover {
color: #70aeed;
}
}
}
</style>到此這篇關(guān)于vue3 el-upload單張圖片回顯、編輯、刪除功能的文章就介紹到這了,更多相關(guān)vue3 el-upload圖片回顯編輯、刪除內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Vue數(shù)據(jù)更新視圖不更新的幾種解決方案小結(jié)
這篇文章主要介紹了Vue數(shù)據(jù)更新視圖不更新的幾種解決方案小結(jié),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-08-08
關(guān)于Vue實(shí)例創(chuàng)建的整體流程
這篇文章主要介紹了關(guān)于Vue實(shí)例創(chuàng)建的整體流程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-06-06
vue3中的elementPlus全局組件中文轉(zhuǎn)換方式
這篇文章主要介紹了vue3中的elementPlus全局組件中文轉(zhuǎn)換方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-07-07
vue自定義密碼輸入框解決瀏覽器自動(dòng)填充密碼的問(wèn)題(最新方法)
這篇文章主要介紹了vue自定義密碼輸入框解決瀏覽器自動(dòng)填充密碼的問(wèn)題,通過(guò)將密碼輸入框的type設(shè)置為text,修改樣式上的顯示,來(lái)實(shí)現(xiàn)既可以讓瀏覽器不自動(dòng)填充密碼,又可以隱藏密碼的效果,需要的朋友可以參考下2023-04-04
Vue實(shí)現(xiàn)JSON字符串格式化編輯器組件功能
這篇文章主要介紹了Vue實(shí)現(xiàn)JSON字符串格式化編輯器組件,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2024-01-01
vue學(xué)習(xí)筆記之v-if和v-show的區(qū)別
本篇文章主要介紹了vue學(xué)習(xí)筆記之v-if和v-show的區(qū)別,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2017-09-09
vue常用指令實(shí)現(xiàn)學(xué)生錄入系統(tǒng)的實(shí)戰(zhàn)
本文主要介紹了vue常用指令實(shí)現(xiàn)學(xué)生錄入系統(tǒng)的實(shí)戰(zhàn),文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-02-02
Vue3 openlayers加載瓦片地圖并手動(dòng)標(biāo)記坐標(biāo)點(diǎn)功能
這篇文章主要介紹了 Vue3 openlayers加載瓦片地圖并手動(dòng)標(biāo)記坐標(biāo)點(diǎn)功能,我們這里用vue/cli創(chuàng)建,我用的node版本是18.12.1,本文結(jié)合示例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2024-04-04

