成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久

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

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

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

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

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

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

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

#第一種解決辦法

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

代碼:

import {ImagePreview} from ’vant’;export default { data() { return {active_:’’, //切換 tab 所對應的狀態數字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中引入并設置好各種參數,當然如果您對效果要求不高,可以不設,許多默認的也夠您使用了。里面有許多不用的功能,員外都 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的,大多數的教程里面都是教您如何預覽多張圖片,但是員外的需要是只需要預覽一張,所以在使用的時候也是繞了一點彎子的。 在 .vue 組件中使用: 首先員外先介紹一下多圖片的使用方法: html中:

<template> <div id='index'> <ul> <li v-for='(item, index) in imgArr' :key='index'> <img :src='http://www.piao2010.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.piao2010.com/bcjs/warsher_before_img' alt='' id='warsher_before_img'></div>//jsmounted() { //調用就是這么簡單,直接 new 一個新 Viewer 對象即可 const viewer = new Viewer(document.getElementById(’warsher_before_img’))}

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

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

標簽: Vue
相關文章:
成人在线亚洲_国产日韩视频一区二区三区_久久久国产精品_99国内精品久久久久久久
国产精品国产自产拍高清av王其| 亚洲日本激情| 日韩视频精品在线观看| 久久伊人蜜桃av一区二区| 久久疯狂做爰流白浆xx| 91黄色激情网站| 日韩精品一卡二卡三卡四卡无卡| 亚洲欧美日本日韩| 亚洲一区二区中文在线| 一本色道久久综合一区| 亚洲精选免费视频| 亚洲精品一区二区三| 亚洲精品中文在线观看| 亚洲另类视频| 亚洲福利电影网| 久久久夜夜夜| 久久精品国产精品亚洲综合| 欧美色涩在线第一页| 久久精品理论片| 欧美日韩精品欧美日韩精品一综合| 久久精品免费观看| 欧美美女一区二区三区| 国产一区 二区 三区一级| 日韩一区二区中文字幕| 成人av电影在线| 国产亚洲欧美一级| 欧美系列一区| 一区二区三区在线不卡| 久久久久久久欧美精品| 久久精品久久精品| 91精品国产免费久久综合| 成人国产亚洲欧美成人综合网| 久久久久久免费| 欧美三级网页| 亚洲一区二区在线播放相泽 | 色综合中文综合网| thepron国产精品| 国产亚洲人成网站| 亚洲电影自拍| 午夜不卡在线视频| 精品视频一区三区九区| 国产99久久久国产精品潘金| 久久久99精品久久| 99精品欧美一区二区三区| 天天操天天色综合| 91精品国产91久久久久久一区二区| 从欧美一区二区三区| 国产精品久久久一本精品| 国产精品五区| 国产毛片精品国产一区二区三区| 久久日韩粉嫩一区二区三区| 国内自拍亚洲| 日韩高清不卡在线| 欧美v日韩v国产v| 尤物在线精品| 免费观看一级欧美片| 精品捆绑美女sm三区| 亚洲精品美女久久7777777| 日本三级韩国三级欧美三级| 欧美一区二区三区喷汁尤物| 午夜久久美女| 午夜婷婷国产麻豆精品| 欧美一区二区三区四区五区| 欧美婷婷久久| 日韩有码一区二区三区| 精品国产3级a| 亚洲精品字幕| 国产一区二区伦理片| 国产精品久久三| 在线精品观看国产| 欧美永久精品| 亚洲成人综合在线| 欧美一级电影网站| 一区二区三区视频在线播放| 狠狠色伊人亚洲综合成人| 欧美激情中文不卡| 在线一区二区视频| 色综合天天综合网国产成人综合天| 亚洲午夜精品网| 日韩欧美国产三级| 国产精品一区视频网站| 国产精品1024| 亚洲影视在线观看| 精品久久久久久久人人人人传媒| 国产欧美日韩综合一区在线播放 | 日本伊人色综合网| 日韩欧美一二区| 国产精品五区| 99视频有精品| 午夜婷婷国产麻豆精品| 久久一区二区视频| 久久不射网站| 色综合色综合色综合色综合色综合 | 国产精品自拍在线| 自拍偷在线精品自拍偷无码专区 | 亚洲欧美激情视频在线观看一区二区三区| 欧美日韩一区国产| 亚洲精品一区二区三区av| 国产精品中文字幕欧美| 亚洲黄色在线视频| 欧美一级欧美三级| 久久国产精品久久w女人spa| 欧美 亚欧 日韩视频在线| 久久国产乱子精品免费女| 亚洲视频一区在线观看| 日韩欧美成人午夜| 色视频成人在线观看免| 欧美日本在线| 国产精品99久久久久久久女警| 亚洲影院理伦片| 国产日韩欧美高清在线| 欧美日韩黄色一区二区| 日韩一级网站| 欧美高清视频一区二区三区在线观看| 久久www免费人成看片高清| 一区视频在线播放| 欧美mv日韩mv国产| 欧美午夜一区二区三区免费大片| 欧美日韩国产综合在线| 国产综合久久久久影院| 亚洲午夜视频在线观看| 国产午夜精品久久久久久免费视 | 丝袜美腿亚洲一区| 国产精品麻豆99久久久久久| 日韩免费福利电影在线观看| 在线观看日韩av先锋影音电影院| 亚洲少妇在线| 欧美一区二区三区四区在线观看地址| 精品系列免费在线观看| 亚洲国产精品综合小说图片区| 国产精品免费久久| 欧美精品一区二区在线观看| 欧美亚洲一区二区在线观看| 国产精品久久久一区二区| 欧美在线首页| 成人午夜在线播放| 国产一区999| 美国欧美日韩国产在线播放| 亚洲小说春色综合另类电影| 一色桃子久久精品亚洲| 国产日韩欧美精品一区| 精品欧美久久久| 欧美日韩综合在线免费观看| 久久婷婷麻豆| 国产九九精品| 99日韩精品| 亚洲高清123| 国内精品久久久久久久影视麻豆| 欧美一区亚洲| 91视频在线观看| 波多野结衣的一区二区三区| 国产九九视频一区二区三区| 精品一区二区免费看| 免费国产亚洲视频| 日韩精品成人一区二区三区| 亚洲va国产天堂va久久en| 亚洲另类春色国产| 成人免费在线视频| 亚洲欧洲av一区二区三区久久| 久久精品人人做人人爽97| 欧美成人艳星乳罩| 日韩一区二区三| 欧美一区二区久久| 欧美一区二区三区婷婷月色| 91麻豆精品91久久久久同性| 欧美高清视频在线高清观看mv色露露十八| 欧亚一区二区三区| 日本二三区不卡| 色妞www精品视频| 久久aⅴ国产紧身牛仔裤| 亚洲一区免费看| 免费视频一区| 正在播放亚洲| 欧美资源在线| 91福利在线观看| 欧美中文字幕一二三区视频| 91官网在线观看| 欧美日本一道本| 欧美一区二区免费观在线| 欧美一级二级在线观看| 日韩精品中午字幕| 精品福利在线导航| 久久婷婷久久一区二区三区| 久久久久久一级片| 中文字幕日韩精品一区| 亚洲欧美日韩电影| 亚洲成人av免费| 亚洲不卡一区二区三区| 免费精品99久久国产综合精品| 蜜桃一区二区三区在线| 麻豆国产欧美一区二区三区| 国内精品不卡在线| 成人av免费在线观看| 欧美日韩一区二区三区在线观看免| 精品动漫3d一区二区三区免费版 | 国产伦精品一区二区三区四区免费 | 亚洲综合不卡| 欧美中文字幕亚洲一区二区va在线 | 亚洲1区2区3区4区| 精品综合免费视频观看|