色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術(shù)文章
文章詳情頁

vue+vant使用圖片預(yù)覽功能ImagePreview的問題解決

瀏覽:91日期:2023-01-27 13:28:04

如果您搜到這篇文章的話,那員外估計您遇到跟我一樣的問題了,即在打開圖片預(yù)覽功能后,如果不關(guān)閉預(yù)覽的圖片,同時改變路由的話,會發(fā)現(xiàn)即使路由改變了,預(yù)覽的圖片還在文檔的最頂層顯示,如圖:

vue+vant使用圖片預(yù)覽功能ImagePreview的問題解決

著實讓員外百思不其解,在調(diào)用vant 的 ImagePreview圖片預(yù)覽組件中,沒有html,有的只是引入ImagePreview 和js的調(diào)用。在這種情況下,員外是想自己添加任何方法都沒法實現(xiàn)的,同時想在離開路由時的beforeRouteLeave 鉤子中關(guān)閉這個 ImagePreview 也實現(xiàn)不了,因為根本就拿他沒有一點辦法。同時可以看到,這個圖片預(yù)覽的 html 是掛載在 window 上面的,實在是太 難為初學(xué)者了。

vue+vant使用圖片預(yù)覽功能ImagePreview的問題解決

#第一種解決辦法

后來多方請教,終于請到一位大佬,為員外指點迷津。 1. 首先需要定義兩個實際變量,instance_before 和 instance_after,之所以是兩個是因為在這個頁面有兩個 tab 里面的圖片需要預(yù)覽; 2. 然后把兩個 ImagePreview[] 分別賦值給instance_before 和 instance_after,測試一下圖片是否能正常打開關(guān)閉,結(jié)果當(dāng)然是可以的; 3. 然后在 beforeRouteLeave 鉤子中調(diào)用 close() 方法關(guān)閉預(yù)覽遮罩。 其實這個問題主要還是單頁只有一個vue實例,然后在調(diào)用 ImagePreview[] 的時候頁面在返回上一個路由或前進到下一個路由,其產(chǎn)生的DOM節(jié)點還存在頁面中,所以要做的是在當(dāng)前路由跳轉(zhuǎn)的時候及時移除或者隱藏這個DOM節(jié)點。

代碼:

import {ImagePreview} from ’vant’;export default { data() { return {active_:’’, //切換 tab 所對應(yīng)的狀態(tài)數(shù)字instance_before:’’,instance_after:’’, } }, //在路由離開的時候,關(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],}); }, }}

#第二種解決辦法

這個辦法就與 vant 無關(guān)了,員外使用的是 viewerjs 插件,這是一款專門針對圖片預(yù)覽打造的插件,功能要比 vant 自帶的全得多,而且自帶很多鉤子功能,如果您需求比較復(fù)雜的話,那使用起來真的是太方便了。 ##使用方法: 安裝依賴 npm i viewerjs -S 在 main.js中引入并設(shè)置好各種參數(shù),當(dāng)然如果您對效果要求不高,可以不設(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, //是否可以移動 'zoomable': true, //是否可以縮放 'rotatable': true, //是否可旋轉(zhuǎn) 'scalable': true, //是否可翻轉(zhuǎn) 'transition': true, //使用 CSS3 過度 'fullscreen': true, //播放時是否全屏 'keyboard': false, //是否支持鍵盤 'url': 'data-source', ready: function (e) { console.log(e.type,’組件以初始化’); }, show: function (e) { console.log(e.type,’圖片顯示開始’); }, 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,’視圖開始’); }, viewed: function (e) { console.log(e.type,’視圖結(jié)束’); }, zoom: function (e) { console.log(e.type,’圖片縮放開始’); }, zoomed: function (e) { console.log(e.type,’圖片縮放結(jié)束’); }});

設(shè)置好之后即可直接使用了。這里有一個小坑,員外在網(wǎng)上查了挺多 demo的,大多數(shù)的教程里面都是教您如何預(yù)覽多張圖片,但是員外的需要是只需要預(yù)覽一張,所以在使用的時候也是繞了一點彎子的。 在 .vue 組件中使用: 首先員外先介紹一下多圖片的使用方法: html中:

<template> <div id='index'> <ul> <li v-for='(item, index) in imgArr' :key='index'> <img :src='http://www.lshqa.cn/bcjs/item' /> </li> </ul> </div></template>```js```data() { return { imgArr: [ '圖片地址', '圖片地址', '圖片地址', '圖片地址', '圖片地址', ] }; }, mounted() { //調(diào)用就是這么簡單,直接 new 一個新 Viewer 對象即可 const viewer = new Viewer(document.getElementById('index'), {}); }

單個圖片的使用方法其實跟上面的例子幾乎一樣: //html

<div class='img-box'> <img :src='http://www.lshqa.cn/bcjs/warsher_before_img' alt='' id='warsher_before_img'></div>//jsmounted() { //調(diào)用就是這么簡單,直接 new 一個新 Viewer 對象即可 const viewer = new Viewer(document.getElementById(’warsher_before_img’))}

切記,千萬不要多事在事件中調(diào)用上面 mounted 中的方法,會導(dǎo)致在第一次觸發(fā)事件的時候,Viewer 實例才剛剛生成,但是不會被調(diào)用,然后在第二次觸發(fā)事件的時候,才會生效。別問我怎么知道的。。。

到此這篇關(guān)于vue+vant使用圖片預(yù)覽功能ImagePreview的問題解決的文章就介紹到這了,更多相關(guān)vue+vant 圖片預(yù)覽ImagePreview內(nèi)容請搜索好吧啦網(wǎng)以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持好吧啦網(wǎng)!

標(biāo)簽: Vue
相關(guān)文章:
主站蜘蛛池模板: 国产亚洲小视频 | 中文字幕一区二区三区 精品 | 日本天堂网在线观看 | 成人香蕉视频 | 日韩欧美在线视频一区二区 | 国产成人精品午夜免费 | 欧美日韩在线观看免费 | 国产一级做a爰片在线看 | 亚洲精品欧洲一区二区三区 | 欧美大片一级特黄 | 18免费网站 | 久久草在线 | 在线a毛片免费视频观看 | 欧美黑寡妇特a级做爰 | 成人资源在线 | 美国免费高清一级毛片 | 免费的成人a视频在线观看 免费的毛片 | 国产真实乱子伦精品 | 国产成人精品视频一区二区不卡 | 国产一区亚洲二区 | 亚洲精品高清视频 | 日本精品高清一区二区2021 | 特黄日韩免费一区二区三区 | 精品国产一区二区三区不卡 | 日本不卡一二三区 | 欧美综合在线观看 | 精品国产亚洲人成在线 | 精品久久久久久免费影院 | 欧美成人三级网站在线观看 | 毛片成人 | 一级v片| 日韩不卡一级毛片免费 | 国产三级国产精品国产国在线观看 | 欧美日韩加勒比一区二区三区 | 国产成人高清亚洲一区91 | 成人α片 | 手机在线日韩高清理论片 | 一级特黄特黄的大片免费 | 91精品免费久久久久久久久 | 久草在线免费福利视频 | 怡红院美国十次成人影院 |