vue中el-upload結合vuedraggable實現圖片的上傳、排序、刪除以及預覽等功能

實現效果:

功能實現:

要實現圖片的拖拽功能首先需要安裝vuedraggable庫

npm install vuedraggable --save

在組件中引入并注冊 vuedraggable

<script>import draggable from "vuedraggable";export default {// 注冊組件components: {draggable,},data(){return {}}}
</script>

?使用element ui的el-upload組件,結合vuedraggable實現圖片的上傳與排序功能

<el-form-item label="上傳輪播圖" prop="image"><ul class="image-upload"><draggable v-model="fileList" @update="dataDragEnd"><transition-group class="uploader"><div v-for="(item, index) in fileList" :key="item.url" class="upload-list"><img v-if="item.url" style="width:146px;height: 146px" :src="item.url"><div class="icon-container"><span v-if="item.url" @click="handlePreviewNew(index)"><i class="el-icon-zoom-in"></i></span><span v-if="item.url" @click="handleRemoveNew(item, index)"><i class="el-icon-delete"></i></span></div></div></transition-group></draggable><el-upload name="image" ref="uploadFile" class="upload-demo" action="#" multiple:on-preview="handlePreview" :on-remove="handleRemove" :http-request="uolpadMorePic" :file-list="fileList" list-type="picture-card"><el-button size="small" type="primary">點擊上傳</el-button></el-upload></ul>
</el-form-item><!-- 圖片回顯預覽 --><el-dialog title="圖片預覽" :visible.sync="previewVisible" width="50%" append-to-body><img :src="previewPath" alt="" style="width:100%;height:100%" /></el-dialog>

上傳圖片時處理方法

uolpadMorePic(file) {let up = new FormData();up.append("image", file.file);up.append("name", this.editForm.name);//上傳圖片接口bannerUp(up).then((res) => {if (res.status == "0000") {this.fileList.push({name: res.data.imageUrl,url: res.data.imageUrl,uid: Math.floor(Math.random() * 100000),})//上傳的圖片和回顯的圖片進行重新排序this.fileList.map((item, index) =>item.sortNum = index + 1)this.$message({type: "success",message: "上傳成功",});} else {this.$message({type: "error",message: res.codemsg,});let uid = file.uid; // 關鍵作用代碼,去除文件列表失敗文件let idx = this.$refs.uploadFile.uploadFiles.findIndex((item) => item.uid === uid); // 關鍵作用代碼,去除文件列表失敗文件(uploadFiles為el-upload中的ref值)this.$refs.uploadFile.uploadFiles.splice(idx, 1); // 關鍵作用代碼,去除文件列表失敗文件}}).catch((err) => {console.log(err);let uid = file.uid; // 關鍵作用代碼,去除文件列表失敗文件let idx = this.$refs.uploadFile.uploadFiles.findIndex((item) => item.uid === uid); // 關鍵作用代碼,去除文件列表失敗文件(uploadFiles為el-upload中的ref值)this.$refs.uploadFile.uploadFiles.splice(idx, 1); // 關鍵作用代碼,去除文件列表失敗文件});},

圖片查看、刪除及拖拽排序

//刪除圖片handleRemoveNew(file, index) {this.fileList.splice(index, 1)},// 處理圖片預覽效果handlePreviewNew(index) {this.previewPath = this.fileList[index].urlthis.previewVisible = true},//拖拽圖片排序dataDragEnd() {// 拖拽圖片更換位置 并重新從1開始排序this.fileList.forEach((item, index) => {item.sortNum = index + 1})//過濾一下url為空的數據this.fileList = this.fileList.filter(item => {return item.url != ''});},

編輯彈窗圖片回顯

let res = 接口獲取的詳情數據
res.data.slider_image.map((item, index) => {this.fileList.push({url: item.url ,name: item.name,sortNum: index + 1,});
});

一些樣式

<style lang="scss" scoped>
.image-upload {display: flex;list-style-type: none;margin: 0;padding: 0;.uploader {display: flex;align-items: center;.upload-list {margin-right: 8px;width: 146px;height: 146px;border-radius: 8px;overflow: hidden;border: 1px solid #c0ccda;position: relative;&:hover {.icon-container {display: block;transition: all 0.5s;}}.icon-container {position: absolute;display: none;transition: all 0.5s;width: 146px;height: 146px;line-height: 146px;color: #fff;font-size: 20px;text-align: center;border-radius: 8px;top: 0;left: 0;background-color: rgba(0, 0, 0, .5);span {margin: 0 10px;cursor: pointer;}}}}
}
</style>
<style scoped>
//此處一定要將原el-upload的圖片回顯list隱藏,用自己寫的
/deep/ .upload-demo .el-upload-list {display: none;
}
</style>

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/209535.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/209535.shtml
英文地址,請注明出處:http://en.pswp.cn/news/209535.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

SI24R03 高度集成低功耗SOC 2.4G 收發一體芯片

今天給大家介紹一款Soc 2.4G 收發一體模塊-SI24R03 Si24R03是一款高度集成的低功耗無線SOC芯片&#xff0c;芯片為QFN32 5x5mm封裝&#xff0c;集成了資源豐富的MCU內核與2.4G收發器模塊&#xff0c;最低功耗可達1.6uA&#xff0c;極少外圍器件&#xff0c;大幅降低系統應用成本…

詳解Android單元測試最佳實踐

目的 充分的單元測試就是提高代碼質量最有效的手段之一&#xff0c;而單元測試嚴重依賴代碼的可測試性&#xff0c;本文主要通過一個簡單的DEMO演示如何對Android原生應用進行單元測試&#xff0c;同時示例代碼采用MVP模式以提高代碼的可讀性和可測試性 簡介 在Android原生應…

mmdetection測試保存到新的文件夾,無需標簽

這個是用demo這個代碼測試的&#xff0c;需要先訓練一個pth文件夾&#xff0c;訓練之后再調用pth文件夾進行測試。測試的代碼文件名是&#xff1a;image_demo_new.py&#xff0c;代碼如系所示&#xff1a; # Copyright (c) OpenMMLab. All rights reserved. import asyncio fr…

使用selenium的edge瀏覽器登錄某為

互聯網上基本都是某哥的用法&#xff0c;其實edge和某哥的用法是一樣的就有一下參數不一樣。 一、運行環境 Python&#xff1a;3.7 Selenium&#xff1a;4.11.2 Edge&#xff1a;版本 120.0.2210.61 (正式版本) (64 位) 二、執行代碼 from time import sleepfrom selenium…

調新浪分享

前端寫一個按鈕,通過按鈕來調出新浪界面, window.location.href http://service.weibo.com/share/share.php?url 這行代碼調出新浪分享界面,要是想要添加一些圖片和文字 使用: window.location.href http://service.weibo.com/share/share.php?url encodeURIComponent…

P2 Qt Creator創建第一個Qt程序

前言 &#x1f3ac; 個人主頁&#xff1a;ChenPi &#x1f43b;推薦專欄1: 《C_ChenPi的博客-CSDN博客》??? &#x1f525; 推薦專欄2: 《LLinux C應用編程&#xff08;概念類&#xff09;_ChenPi的博客-CSDN博客》??? &#x1f33a;本篇簡介 &#xff1a;這一章我們學…

Python基礎——兩個常用且容易忘記的知識點

1. replace函數的第三個參數 replace 方法提供了一個可選的參數 count&#xff0c;可以用于指定替換的次數。你可以將 count 設置為 1 來限制替換的次數&#xff0c;只替換第一個匹配項。 下面是使用 replace 方法限制替換次數的示例&#xff1a; date_str "2023/05/1…

二百一十一、Flume——Flume實時采集Linux中的Hive日志寫入到HDFS中(親測、附截圖)

一、目的 為了實現用Flume實時采集Hive的操作日志到HDFS中&#xff0c;于是進行了一場實驗 二、前期準備 &#xff08;一&#xff09;安裝好Hadoop、Hive、Flume等工具 &#xff08;二&#xff09;查看Hive的日志在Linux系統中的文件路徑 [roothurys23 conf]# find / -name…

smarty模版 [BJDCTF2020]The mystery of ip 1

打開題目 點擊flag給了我們一個ip 點擊hint&#xff0c;查看源代碼處告訴了我們要利用這個ip bp抓包&#xff0c;并添加X-Forward-For頭 所以這道題是XFF可控 本來聯想到XFF漏洞引起的sql注入&#xff0c;但是我們無論輸入什么都會正常回顯&#xff0c;就聯想到ssti注入 我們…

C/C++指針操作整理

C/C指針操作整理 面向曾經學習過指針的人&#xff0c;并非針對究極初學者。 一維指針 數據類型存儲的地址&#xff0c;指向數據存儲的地址&#xff0c;可以使用 &運算符取變量的地址&#xff0c;將其賦給指針變量。 int a 2; int *p &a;同時因為C/C中數組是連續存儲…

Java實現插入排序算法

插入排序算法 &#xff08;1&#xff09;概念&#xff1a;通過構建有序序列&#xff0c;對于未排序數據&#xff0c;在已排序序列中從后向前掃描&#xff0c;找到相應的位置并插入。 &#xff08;2&#xff09;一個通俗的比喻&#xff1a; 插入排序就類似于斗地主時&#xf…

CloudCompare 二次開發(23)——計算兩點云之間的放縮倍數

目錄 一、概述二、代碼集成三、結果展示一、概述 使用CloudCompare編程實現計算兩點云之間的放縮倍數。具體計算原理見:。 二、代碼集成 1、mainwindow.h文件public中添加: void doActionComputeScale(); // 計算兩點云的放縮倍數2、mainwindow.cpp文件void MainWin…

vue-element使用html2canvas實現網頁指定區域(指定dom元素)截圖

直接上代碼&#xff1a; <template><el-dialog :visible.sync"printDialogVisible" width"1000px" :close-on-click-modal"false" append-to-body><template><div :id"print_content" ref"print_content&q…

Python網絡爬蟲的基礎理解-對應的自我理解誤區

##通過一個中國大學大學排名爬蟲的示例進行基礎性理解 以軟科中國最好大學排名為分析對象&#xff0c;基于requests庫和bs4庫編寫爬蟲程序&#xff0c;對2015年至2019年間的中國大學排名數據進行爬取&#xff1a;&#xff08;1&#xff09;按照排名先后順序輸出不同年份的前10…

Linux下通過find找文件---通過修改時間查找(-mtime)

通過man手冊查找和-mtime選項相關的內容 man find | grep -A 3 mtime # 這里簡單介紹了 -mtime &#xff0c;還有一個簡單的示例-mtime n Files data was last modified n*24 hours ago. See the comments for -atime to understand how rounding affects the interpretati…

【已解決】解決Win7虛擬機打開網頁報錯的情況

因為剛才下載了個虛擬機&#xff0c;同樣出現了無法安裝VMtools的情況&#xff0c;所以想直接通過虛擬機的瀏覽器來下載一個補丁&#xff08;因為自己的U盤在虛擬機上面無法識別&#xff0c;應該是太老了Win7&#xff09; 結果發現Win7內置的IE瀏覽器太拉了。于是向下載一個火…

深度學習記錄--神經網絡表示及其向量化

神經網絡表示 如下圖 就這個神經網絡圖來說&#xff0c;它有三層&#xff0c;分別是輸入層(Input layer)&#xff0c;隱藏層(Hidden layer)&#xff0c;輸出層(Output layer) 對于其他的神經網絡&#xff0c;隱藏層可以有很多層 一般來說&#xff0c;不把輸入層算作一個標準…

【ITK庫學習】使用itk庫進行圖像濾波ImageFilter:幾何變換:翻轉、重采樣(未完)

目錄 1、itkFlipImageFilter 圖像翻轉濾波器2、itkResampleImageFilter 重采樣圖像濾波器 1、itkFlipImageFilter 圖像翻轉濾波器 該類的主要功能是使輸入數據在用戶指定的軸上進行翻轉。 翻轉軸通過函數SetFlipAxes(array) 設置&#xff0c;其中輸入是FixArray<bool,Imag…

UML圖的各種類型以及軟件設計師考試考察的方式

UML建模 前言 常見的UML的類型 UML 比前兩題是更難的&#xff08;略高&#xff0c;但是學會就可以了。前兩題是&#xff1a;數據流圖&#xff0c;數據庫的設計&#xff09;&#xff0c;因為UML圖有很多類型&#xff1a;用例圖&#xff0c;類圖與對象圖&#xff0c;順序圖&…

3_CSS層疊樣式表基礎

第3章-CSS層疊樣式表基礎 學習目標(Objective) 掌握標簽選擇器的使用掌握類選擇器的使用了解id選擇器和通配符選擇器掌握font屬性和color屬性的應用 1.HTML的局限性 如果要改變下高度或者變一個顏色&#xff0c;就需要大量重復操作 總結&#xff1a; HTML滿足不了設計者的需…