您好,登錄后才能下訂單哦!
這篇文章主要講解了解決vue+vant使用圖片預(yù)覽功能ImagePreview的問(wèn)題,內(nèi)容清晰明了,對(duì)此有興趣的小伙伴可以學(xué)習(xí)一下,相信大家閱讀完之后會(huì)有幫助。
如果您搜到這篇文章的話(huà),那員外估計(jì)您遇到跟我一樣的問(wèn)題了,即在打開(kāi)圖片預(yù)覽功能后,如果不關(guān)閉預(yù)覽的圖片,同時(shí)改變路由的話(huà),會(huì)發(fā)現(xiàn)即使路由改變了,預(yù)覽的圖片還在文檔的最頂層顯示,如圖:
著實(shí)讓員外百思不其解,在調(diào)用vant 的 ImagePreview圖片預(yù)覽組件中,沒(méi)有html,有的只是引入ImagePreview 和js的調(diào)用。在這種情況下,員外是想自己添加任何方法都沒(méi)法實(shí)現(xiàn)的,同時(shí)想在離開(kāi)路由時(shí)的beforeRouteLeave 鉤子中關(guān)閉這個(gè) ImagePreview 也實(shí)現(xiàn)不了,因?yàn)楦揪湍盟麤](méi)有一點(diǎn)辦法。同時(shí)可以看到,這個(gè)圖片預(yù)覽的 html 是掛載在 window 上面的,實(shí)在是太 難為初學(xué)者了。
#第一種解決辦法
后來(lái)多方請(qǐng)教,終于請(qǐng)到一位大佬,為員外指點(diǎn)迷津。 1. 首先需要定義兩個(gè)實(shí)際變量,instance_before 和 instance_after,之所以是兩個(gè)是因?yàn)樵谶@個(gè)頁(yè)面有兩個(gè) tab 里面的圖片需要預(yù)覽; 2. 然后把兩個(gè) ImagePreview[] 分別賦值給instance_before 和 instance_after,測(cè)試一下圖片是否能正常打開(kāi)關(guān)閉,結(jié)果當(dāng)然是可以的; 3. 然后在 beforeRouteLeave 鉤子中調(diào)用 close() 方法關(guān)閉預(yù)覽遮罩。 其實(shí)這個(gè)問(wèn)題主要還是單頁(yè)只有一個(gè)vue實(shí)例,然后在調(diào)用 ImagePreview[] 的時(shí)候頁(yè)面在返回上一個(gè)路由或前進(jìn)到下一個(gè)路由,其產(chǎn)生的DOM節(jié)點(diǎn)還存在頁(yè)面中,所以要做的是在當(dāng)前路由跳轉(zhuǎn)的時(shí)候及時(shí)移除或者隱藏這個(gè)DOM節(jié)點(diǎn)。
代碼:
import {ImagePreview} from 'vant'; export default { data() { return { active_:'', //切換 tab 所對(duì)應(yīng)的狀態(tài)數(shù)字 instance_before:'', instance_after:'', } }, //在路由離開(kāi)的時(shí)候,關(guān)閉預(yù)覽的圖片 beforeRouteLeave(to,from,next){ if(this.active_ == 0){ this.instance_before.close(); }else{ this.instance_after.close(); } next(); }, methods: { //查看圖片 show_before_img(){ this.instance_before = ImagePreview({ images: [this.warsher_brfore], }); }, show_after_img(){ this.instance_after = ImagePreview({ images: [this.warsher_after], }); }, } }
#第二種解決辦法
這個(gè)辦法就與 vant 無(wú)關(guān)了,員外使用的是 viewerjs 插件,這是一款專(zhuān)門(mén)針對(duì)圖片預(yù)覽打造的插件,功能要比 vant 自帶的全得多,而且自帶很多鉤子功能,如果您需求比較復(fù)雜的話(huà),那使用起來(lái)真的是太方便了。 ##使用方法: 安裝依賴(lài) npm i viewerjs -S 在 main.js中引入并設(shè)置好各種參數(shù),當(dāng)然如果您對(duì)效果要求不高,可以不設(shè),許多默認(rèn)的也夠您使用了。里面有許多不用的功能,員外都 false 了。
import Viewer from 'v-viewer' import 'viewerjs/dist/viewer.css' Viewer.setDefaults({ 'inline':false, 'button':true, //右上角按鈕 "navbar": false, //底部縮略圖 "title": false, //當(dāng)前圖片標(biāo)題 "toolbar": false, //底部工具欄 "tooltip": false, //顯示縮放百分比 "movable": true, //是否可以移動(dòng) "zoomable": true, //是否可以縮放 "rotatable": true, //是否可旋轉(zhuǎn) "scalable": true, //是否可翻轉(zhuǎn) "transition": true, //使用 CSS3 過(guò)度 "fullscreen": true, //播放時(shí)是否全屏 "keyboard": false, //是否支持鍵盤(pán) "url": "data-source", ready: function (e) { console.log(e.type,'組件以初始化'); }, show: function (e) { console.log(e.type,'圖片顯示開(kāi)始'); }, shown: function (e) { console.log(e.type,'圖片顯示結(jié)束'); }, hide: function (e) { console.log(e.type,'圖片隱藏完成'); }, hidden: function (e) { console.log(e.type,'圖片隱藏結(jié)束'); }, view: function (e) { console.log(e.type,'視圖開(kāi)始'); }, viewed: function (e) { console.log(e.type,'視圖結(jié)束'); }, zoom: function (e) { console.log(e.type,'圖片縮放開(kāi)始'); }, zoomed: function (e) { console.log(e.type,'圖片縮放結(jié)束'); } });
設(shè)置好之后即可直接使用了。這里有一個(gè)小坑,員外在網(wǎng)上查了挺多 demo的,大多數(shù)的教程里面都是教您如何預(yù)覽多張圖片,但是員外的需要是只需要預(yù)覽一張,所以在使用的時(shí)候也是繞了一點(diǎn)彎子的。 在 .vue 組件中使用: 首先員外先介紹一下多圖片的使用方法: html中:
<template> <div id="index"> <ul> <li v-for="(item, index) in imgArr" :key="index"> <img :src="item" /> </li> </ul> </div> </template> ``` js ``` data() { return { imgArr: [ "圖片地址", "圖片地址", "圖片地址", "圖片地址", "圖片地址", ] }; }, mounted() { //調(diào)用就是這么簡(jiǎn)單,直接 new 一個(gè)新 Viewer 對(duì)象即可 const viewer = new Viewer(document.getElementById("index"), {}); }
單個(gè)圖片的使用方法其實(shí)跟上面的例子幾乎一樣: //html
<div class="img-box"> <img :src="warsher_before_img" id="warsher_before_img"> </div> //js mounted() { //調(diào)用就是這么簡(jiǎn)單,直接 new 一個(gè)新 Viewer 對(duì)象即可 const viewer = new Viewer(document.getElementById('warsher_before_img')) }
切記,千萬(wàn)不要多事在事件中調(diào)用上面 mounted 中的方法,會(huì)導(dǎo)致在第一次觸發(fā)事件的時(shí)候,Viewer 實(shí)例才剛剛生成,但是不會(huì)被調(diào)用,然后在第二次觸發(fā)事件的時(shí)候,才會(huì)生效。別問(wèn)我怎么知道的。。。
看完上述內(nèi)容,是不是對(duì)解決vue+vant使用圖片預(yù)覽功能ImagePreview的問(wèn)題有進(jìn)一步的了解,如果還想學(xué)習(xí)更多內(nèi)容,歡迎關(guān)注億速云行業(yè)資訊頻道。
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。