vue3 el-upload單張圖片回顯、編輯、刪除功能實(shí)現(xiàn)
vue3 el-upload單張圖片回顯、編輯、刪除功能
圖片回顯時(shí)隱藏上傳區(qū)域,鼠標(biāo)懸浮顯示遮罩層進(jìn)行編輯、刪除操作,刪除圖片后顯示上傳區(qū)域
vue部分:
①el-upload沒有限制上傳文件數(shù)量,如果limit=1,那么點(diǎn)擊編輯時(shí)不會(huì)觸發(fā)on-change事件,需要先清除當(dāng)前文件,頁面會(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) => { //如果上傳的圖片沒有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-06vue3中的elementPlus全局組件中文轉(zhuǎn)換方式
這篇文章主要介紹了vue3中的elementPlus全局組件中文轉(zhuǎn)換方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-07-07vue自定義密碼輸入框解決瀏覽器自動(dòng)填充密碼的問題(最新方法)
這篇文章主要介紹了vue自定義密碼輸入框解決瀏覽器自動(dòng)填充密碼的問題,通過將密碼輸入框的type設(shè)置為text,修改樣式上的顯示,來實(shí)現(xiàn)既可以讓瀏覽器不自動(dòng)填充密碼,又可以隱藏密碼的效果,需要的朋友可以參考下2023-04-04Vue實(shí)現(xiàn)JSON字符串格式化編輯器組件功能
這篇文章主要介紹了Vue實(shí)現(xiàn)JSON字符串格式化編輯器組件,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2024-01-01vue學(xué)習(xí)筆記之v-if和v-show的區(qū)別
本篇文章主要介紹了vue學(xué)習(xí)筆記之v-if和v-show的區(qū)別,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧2017-09-09vue常用指令實(shí)現(xiàn)學(xué)生錄入系統(tǒng)的實(shí)戰(zhàn)
本文主要介紹了vue常用指令實(shí)現(xiàn)學(xué)生錄入系統(tǒng)的實(shí)戰(zhàn),文中通過示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-02-02Vue3 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