vue中關(guān)于element的el-image 圖片預(yù)覽功能增加一個(gè)下載按鈕(操作方法)
項(xiàng)目場(chǎng)景:
工作中我們常用會(huì)到 vue+element,其中預(yù)覽組件難免會(huì)涉及到下載功能,或者其它擴(kuò)展功能,但是el-image 支持的只是 簡(jiǎn)單放大旋轉(zhuǎn)功能,解決方法 要么 修改組件,要么 通過(guò) js動(dòng)態(tài)渲染進(jìn)去,接下來(lái)看操作。
效果圖如下:

一、安裝element-ui
1. 安裝element-ui
在項(xiàng)目終端輸入以下代碼完成element-ui的安裝
npm i element-ui -S
2. 檢查是否安裝成功
查看配置文件package.json,是否有element-ui組件的版本號(hào)

3. 引用element-ui組件
在main.js文件中輸入以下代碼,引入element
import ElementUI from 'element-ui' import 'element-ui/lib/theme-chalk/index.css' Vue.use(ElementUI)
二、改造步驟
修改代碼:
通過(guò)點(diǎn)擊放大時(shí),添加點(diǎn)擊事件,然后通過(guò)append 添加 按鈕并且綁定事件,還是看下圖吧,兄弟們,粘起來(lái)。
<template>
<div style="margin-top: 2vh">
<waterfall
@loadmore="loadmore"
:col=4
:lazy-distance="300"
:load-distance="300"
:data="xx">
<div class="cell-item zxzx demo-image__preview " v-for="(item,index) in xx" :key="index" @click="checkImage" style="padding: 0 1vw;">
<el-image
style="width: 100%; margin-top: 2vh"
:src="item.img1"
:preview-src-list="[item.img]">
</el-image>
<p style="background-color: rgba(0,0,0,0.1); color: #fff; text-align: center; margin-top: -6px;">{{item.createTime}}</p>
</div>
</waterfall>
</div>
</template>
<script>
mounted() {
window.cl = this.cl
},
methods: {
cl() {
let srcUrl=document.querySelector('.el-image-viewer__img').src;
this.downloadIamge(srcUrl,srcUrl)
},
checkImage(){//這個(gè)事件要綁定el-image父級(jí)盒子上
console.log('點(diǎn)擊事件');
let a=document.querySelector('.el-image-viewer__actions__inner');
// $(a).append(`<i class="el-icon-download" onclick="installImage()"></i>`)
// a.append( `<i class="el-icon-download" onclick="cl()"></i>`)
console.log(a)
let ff = document.createElement('i')
ff.innerHTML = `<i class="el-icon-download" onclick="cl()"></i>`
a.appendChild(ff)
},
downloadIamge(imgsrc, name) {//下載圖片地址和圖片名
let image = new Image();
// 解決跨域 Canvas 污染問(wèn)題
image.setAttribute("crossOrigin", "anonymous");
image.onload = function() {
let canvas = document.createElement("canvas");
canvas.width = image.width;
canvas.height = image.height;
let context = canvas.getContext("2d");
context.drawImage(image, 0, 0, image.width, image.height);
let url = canvas.toDataURL("image/png"); //得到圖片的base64編碼數(shù)據(jù)
let a = document.createElement("a"); // 生成一個(gè)a元素
let event = new MouseEvent("click"); // 創(chuàng)建一個(gè)單擊事件
a.download = name || "photo"; // 設(shè)置圖片名稱
a.href = url; // 將生成的URL設(shè)置為a.href屬性
a.dispatchEvent(event); // 觸發(fā)a的單擊事件
};
image.src = imgsrc;
},
}
</script>
最總效果

到此這篇關(guān)于vue中關(guān)于element的el-image 圖片預(yù)覽功能增加一個(gè)下載按鈕的文章就介紹到這了,更多相關(guān)vue element圖片預(yù)覽內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Vue將將后端返回的list數(shù)據(jù)轉(zhuǎn)化為樹(shù)結(jié)構(gòu)的實(shí)現(xiàn)
本文主要介紹了Vue將將后端返回的list數(shù)據(jù)轉(zhuǎn)化為樹(shù)結(jié)構(gòu)的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2022-05-05
實(shí)例詳解Vue項(xiàng)目使用eslint + prettier規(guī)范代碼風(fēng)格
這篇文章主要介紹了Vue項(xiàng)目使用eslint + prettier規(guī)范代碼風(fēng)格,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下2018-08-08
vue?elementui動(dòng)態(tài)添加el-input實(shí)例代碼
最近遇到一個(gè)新的需求,需要?jiǎng)討B(tài)添加el-input,這篇文章主要給大家介紹了關(guān)于vue?elementui動(dòng)態(tài)添加el-input的相關(guān)資料,文中通過(guò)實(shí)例代碼介紹的非常詳細(xì),需要的朋友可以參考下2023-06-06
Vue如何實(shí)現(xiàn)文件預(yù)覽和下載功能的前端上傳組件
在Vue.js項(xiàng)目中,使用ElementUI的el-upload組件可以輕松實(shí)現(xiàn)文件上傳功能,通過(guò)配置組件參數(shù)和實(shí)現(xiàn)相應(yīng)的方法,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下2024-09-09
vue實(shí)現(xiàn)帶自動(dòng)吸附功能的懸浮球
這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)帶自動(dòng)吸附功能的懸浮球,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2022-04-04
Vue+Webpack完美整合富文本編輯器TinyMce的方法
這篇文章主要介紹了Vue+Webpack完美整合富文本編輯器TinyMce的方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2018-11-11

