日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

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

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

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

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

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

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

#第一種解決辦法

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

代碼:

import {ImagePreview} from ’vant’;export default { data() { return {active_:’’, //切換 tab 所對應的狀態(tài)數(shù)字instance_before:’’,instance_after:’’, } }, //在路由離開的時候,關閉預覽的圖片 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 無關了,員外使用的是 viewerjs 插件,這是一款專門針對圖片預覽打造的插件,功能要比 vant 自帶的全得多,而且自帶很多鉤子功能,如果您需求比較復雜的話,那使用起來真的是太方便了。 ##使用方法: 安裝依賴 npm i viewerjs -S 在 main.js中引入并設置好各種參數(shù),當然如果您對效果要求不高,可以不設,許多默認的也夠您使用了。里面有許多不用的功能,員外都 false 了。

import Viewer from ’v-viewer’import ’viewerjs/dist/viewer.css’Viewer.setDefaults({ ’inline’:false, ’button’:true, //右上角按鈕 'navbar': false, //底部縮略圖 'title': false, //當前圖片標題 'toolbar': false, //底部工具欄 'tooltip': false, //顯示縮放百分比 'movable': true, //是否可以移動 'zoomable': true, //是否可以縮放 'rotatable': true, //是否可旋轉 'scalable': true, //是否可翻轉 '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,’圖片顯示結束’); }, hide: function (e) { console.log(e.type,’圖片隱藏完成’); }, hidden: function (e) { console.log(e.type,’圖片隱藏結束’); }, view: function (e) { console.log(e.type,’視圖開始’); }, viewed: function (e) { console.log(e.type,’視圖結束’); }, zoom: function (e) { console.log(e.type,’圖片縮放開始’); }, zoomed: function (e) { console.log(e.type,’圖片縮放結束’); }});

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

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

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

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

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

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

標簽: Vue
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
美女国产精品| 国产成人精品亚洲线观看| 精品欧美一区二区三区在线观看| 国产精品网站在线看| 日本久久二区| 日本aⅴ亚洲精品中文乱码| 91嫩草精品| 国产日产精品_国产精品毛片| 国产欧美一区二区精品久久久| 国产欧美一区二区三区米奇| 国产精品日本一区二区三区在线| 麻豆成人综合网| av免费不卡国产观看| 成人啊v在线| a日韩av网址| 久久婷婷一区| 亚洲一区中文| 亚洲精一区二区三区| 日韩精品亚洲aⅴ在线影院| 欧美日韩亚洲国产精品| 精品成av人一区二区三区| 成人av三级| 天堂资源在线亚洲| 亚洲综合图色| 麻豆国产欧美一区二区三区| 久久影院午夜精品| 日韩一级精品| 欧美亚洲网站| 91精品韩国| 自由日本语亚洲人高潮| 亚洲精品韩国| 精品一区二区男人吃奶| 成人va天堂| 综合亚洲自拍| 精品久久久网| 伊人久久亚洲热| 欧美啪啪一区| 日本少妇一区| 日本免费一区二区视频| 成人一区而且| 老鸭窝毛片一区二区三区| 国产精品chinese| 91精品精品| 欧美专区一区| 久久精品欧美一区| 日本一区福利在线| 亚洲黄色免费av| 一区二区日韩免费看| 岛国av在线播放| 亚洲精品黄色| 久久裸体视频| 国产欧美视频在线| 中文日韩欧美| 老司机精品在线| aⅴ色国产欧美| 精品亚洲精品| 蜜臀av一区二区三区| 丁香婷婷久久| 亚久久调教视频| 亚洲黄色网址| 日本视频一区二区| 欧美日韩三区| 国产精品久久久久蜜臀 | 麻豆国产精品| 日韩影院精彩在线| 成人黄色av| 日韩av中文在线观看| 亚洲第一区色| 国产精品二区不卡| 国产亚洲一区| 亚洲综合三区| 婷婷综合六月| 麻豆成人在线观看| 日韩中文字幕亚洲一区二区va在线| 成人精品国产亚洲| 日本精品另类| 中文欧美日韩| 久久精品国产亚洲夜色av网站| 欧美黄色一区| 日本视频在线一区| 亚洲一区二区日韩| 亚洲女同中文字幕| 日本精品不卡| 国产91在线精品| 欧美1区2区3| 日韩欧美三区| 视频一区二区欧美| 激情婷婷综合| 久久久久久久欧美精品| 久久精品免费看| 国产情侣久久| 蜜桃传媒麻豆第一区在线观看| 欧美一区久久久| 久久亚洲精品中文字幕| 亚洲精品日韩久久| 丝袜美腿亚洲色图| 91精品电影| 99久久夜色精品国产亚洲狼| 国产一区二区三区亚洲综合| 国产精品蜜月aⅴ在线| 国产毛片精品久久| 91精品国产自产精品男人的天堂| 天堂成人国产精品一区| 欧美日韩国产综合网| 欧美亚洲国产一区| 欧美sss在线视频| 久久影视三级福利片| 国产精品亚洲二区| 国产精品亲子伦av一区二区三区| 亚洲97av| 亚洲久久在线| 日韩精品高清不卡| 日产欧产美韩系列久久99| 亚洲深深色噜噜狠狠爱网站| 久热re这里精品视频在线6| 在线亚洲国产精品网站| 国产精品毛片一区二区三区| 欧洲激情综合| 久久福利精品| 综合一区二区三区| 日韩美女国产精品| 亚洲精品伦理| 日韩精品社区| 国产精品任我爽爆在线播放| 91国内精品| 国产精品一国产精品k频道56| 国产精品香蕉| 精品一区二区三区视频在线播放| 精品免费av| 精品国产鲁一鲁****| 精品精品国产三级a∨在线| 福利一区和二区| 久久久久网站| 久久福利影视| 日韩一区二区三区在线看| 69堂免费精品视频在线播放| 国产精品久久久久久久免费软件 | 久久蜜桃av| 国产一区91| 日韩一区二区三区四区五区| 日韩精品乱码av一区二区| 欧美一级二级视频| 久久精品欧洲| 欧美国产偷国产精品三区| 久久久久久美女精品| 在线视频精品| 日韩高清一区二区| 国产精品免费99久久久| 中文一区一区三区高中清不卡免费| 亚洲91久久| 国产精品日本| 国产伦理久久久久久妇女| 麻豆精品蜜桃视频网站| 久久久久久久欧美精品| 精品国产精品久久一区免费式| 日韩精品午夜| 香蕉久久久久久久av网站| 婷婷综合电影| 老色鬼精品视频在线观看播放| 视频二区不卡| 亚洲精品少妇| 国产在线观看www| 一区在线免费观看| 欧美综合二区| 国产欧美日韩影院| 亚洲啊v在线| 丝袜美腿亚洲一区二区图片| 国产伦精品一区二区三区视频| 亚洲精品永久免费视频| 亚洲一二av| 成人在线超碰| 亚洲欧美视频一区二区三区| 国产精品一级| 成人精品亚洲| 日本亚洲视频| 精品午夜视频| 欧美aaaaaa午夜精品| 欧美丝袜一区| 色综合视频一区二区三区日韩| 久久久久黄色| 夜夜嗨一区二区三区| 国产精品久久久久久久久久久久久久久 | 国产精品免费99久久久| 999久久久国产精品| 日本亚洲视频在线| 久久国产直播| 欧美精品国产一区| 偷拍欧美精品| 久久三级毛片| 免费在线视频一区| 成人国产精品一区二区网站| 视频一区视频二区中文字幕| 国产成人久久| 亚洲字幕久久| 国产精品免费99久久久| 视频一区国产视频| 韩国女主播一区二区三区| 亚洲福利精品| 欧美不卡高清| 欧美激情视频一区二区三区免费|