欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時(shí)間:2020年04月10日 11:17:24   作者:劉員外  
這篇文章主要介紹了vue+vant使用圖片預(yù)覽功能ImagePreview的問(wèn)題解決,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

如果您搜到這篇文章的話,那員外估計(jì)您遇到跟我一樣的問(wèn)題了,即在打開(kāi)圖片預(yù)覽功能后,如果不關(guān)閉預(yù)覽的圖片,同時(shí)改變路由的話,會(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 插件,這是一款專門(mén)針對(duì)圖片預(yù)覽打造的插件,功能要比 vant 自帶的全得多,而且自帶很多鉤子功能,如果您需求比較復(fù)雜的話,那使用起來(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" alt="" 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)我怎么知道的。。。

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

相關(guān)文章

  • vue學(xué)習(xí)筆記之slot插槽基本用法實(shí)例分析

    vue學(xué)習(xí)筆記之slot插槽基本用法實(shí)例分析

    這篇文章主要介紹了vue學(xué)習(xí)筆記之slot插槽基本用法,結(jié)合實(shí)例形式分析了vue slot插槽基本使用方法與操作注意事項(xiàng),需要的朋友可以參考下
    2020-02-02
  • vue2項(xiàng)目解決IE、360瀏覽器兼容問(wèn)題的辦法

    vue2項(xiàng)目解決IE、360瀏覽器兼容問(wèn)題的辦法

    雖然已經(jīng)擯棄ie的使用,但是在現(xiàn)階段還是在某些場(chǎng)景下需要用到ie,這篇文章主要給大家介紹了關(guān)于vue2項(xiàng)目解決IE、360瀏覽器兼容問(wèn)題的辦法,文中通過(guò)代碼介紹的非常詳細(xì),需要的朋友可以參考下
    2024-09-09
  • 傻瓜式vuex語(yǔ)法糖kiss-vuex整理

    傻瓜式vuex語(yǔ)法糖kiss-vuex整理

    kiss-vuex 是一個(gè)非常簡(jiǎn)單的語(yǔ)法糖類庫(kù),這篇文章主要介紹了傻瓜式vuex語(yǔ)法糖kiss-vuex整理,非常具有實(shí)用價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2018-12-12
  • vue 實(shí)現(xiàn)拖拽動(dòng)態(tài)生成組件的需求

    vue 實(shí)現(xiàn)拖拽動(dòng)態(tài)生成組件的需求

    這篇文章主要介紹了vue 如何實(shí)現(xiàn)拖拽動(dòng)態(tài)生成組件的需求,幫助大家更好的理解和學(xué)習(xí)使用vue框架,感興趣的朋友可以了解下
    2021-05-05
  • Vue.set與this.$set的用法與使用場(chǎng)景介紹

    Vue.set與this.$set的用法與使用場(chǎng)景介紹

    Vue.set()和this.$set()這兩個(gè)api的實(shí)現(xiàn)原理基本一模一樣,都是使用了set函數(shù),下面這篇文章主要給大家介紹了關(guān)于Vue.set與this.$set的用法與使用場(chǎng)景,需要的朋友可以參考下
    2022-03-03
  • Vue的過(guò)濾器你真了解嗎

    Vue的過(guò)濾器你真了解嗎

    這篇文章主要為大家詳細(xì)介紹了Vue的過(guò)濾器,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助
    2022-02-02
  • 詳解Vue webapp項(xiàng)目通過(guò)HBulider打包原生APP

    詳解Vue webapp項(xiàng)目通過(guò)HBulider打包原生APP

    這篇文章主要介紹了詳解Vue webapp項(xiàng)目通過(guò)HBulider打包原生APP,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-06-06
  • vue登錄注冊(cè)及token驗(yàn)證實(shí)現(xiàn)代碼

    vue登錄注冊(cè)及token驗(yàn)證實(shí)現(xiàn)代碼

    在vue單頁(yè)中,我們可以通過(guò)監(jiān)控route對(duì)象,從中匹配信息去決定是否驗(yàn)證token,然后定義后續(xù)行為。下面通過(guò)實(shí)例代碼給大家分享vue登錄注冊(cè)及token驗(yàn)證功能,需要的朋友參考下吧
    2017-12-12
  • Vue3?setup的注意點(diǎn)及watch監(jiān)視屬性的六種情況分析

    Vue3?setup的注意點(diǎn)及watch監(jiān)視屬性的六種情況分析

    這篇文章主要介紹了Vue3?setup的注意點(diǎn)及watch監(jiān)視屬性的六種情況,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2023-04-04
  • Vue攔截器原理以及詳細(xì)使用方法

    Vue攔截器原理以及詳細(xì)使用方法

    這篇文章主要給大家介紹了關(guān)于Vue攔截器原理以及詳細(xì)使用的相關(guān)資料,Vue攔截器通常用于在發(fā)送請(qǐng)求或響應(yīng)數(shù)據(jù)時(shí)對(duì)其進(jìn)行一些處理或修改,文中通過(guò)代碼示例介紹的非常詳細(xì),需要的朋友可以參考下
    2023-08-08

最新評(píng)論