亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

vue-preview動(dòng)態(tài)獲取圖片寬高并增加旋轉(zhuǎn)功能的實(shí)現(xiàn)

 更新時(shí)間:2020年07月29日 10:39:26   作者:鍵盤(pán)上的草根舞者  
這篇文章主要介紹了vue-preview動(dòng)態(tài)獲取圖片寬高并增加旋轉(zhuǎn)功能的實(shí)現(xiàn),具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧

vue-preview是一個(gè)常用的圖片查看器,微博網(wǎng)頁(yè)版就是用的這個(gè)插件:

我在項(xiàng)目中也用過(guò)這個(gè)插件,總體來(lái)說(shuō),還是比較滿意。但是缺少一個(gè)圖片旋轉(zhuǎn)功能。

安裝使用

第一步:安裝

npm i vue-preview -S

第二步:引用配置

import VuePreview from 'vue-preview'
Vue.use(VuePreview)
Vue.use(preview, {
 mainClass: 'pswp--minimal--dark',
 barsSize: {top: 0, bottom: 0},
 captionEl: false,
 fullscreenEl: false,
 shareEl: false,
 bgOpacity: 0.85,
 tapToClose: true,
 tapToToggleControls: false
})

第三步:使用

// 定義預(yù)覽圖片列表
previewlist: [
  {
    src: ‘./pic01.jpg',
    w: 1200,
    h: 900
  },
  {
    src: ‘./pic01.jpg',
    w: 1200,
    h: 900
  }
]
 
// 給圖片添加“preview-img”類(lèi)(必須添加且要同名),以及綁定“show”方法
<img :src="decodeURIComponent(item.name)" class="preview-img" @click="show(index)">
 
// 點(diǎn)擊圖片觸發(fā)預(yù)覽方法
show (index) {
  this.$preview.open(index, this. previewlist);
}

動(dòng)態(tài)獲取圖片寬高

如果圖片列表資源是從服務(wù)器獲取,則需要先獲取圖片的真實(shí)寬高,具體代碼如下:

this. previewlist = []; //查看列表
let imglist = […]; //從服務(wù)器獲取的圖片地址列表
show (index) {
  for (let i = 0; i < imglist.length; i++) {
    // 獲取圖片實(shí)際大小
    let newImage = {};
    let img = new Image();
    img.src = imglist[i];
    img.onload = function () {
      newImage.src = imglist[i];
      newImage.w = img.width;
      newImage.h = img.height;
    };
    this.previewlist.push(newImage);
  }
  // 正常情況下javascript都是按照順序執(zhí)行的。但是我們可能讓該語(yǔ)句后面的語(yǔ)句執(zhí)行完再執(zhí)行本身,用setTimeout延時(shí)0ms來(lái)實(shí)現(xiàn)。
  setTimeout(() => {
    this.$preview.open(index, this.previewlist);
  }, 0);
}

新增圖片旋轉(zhuǎn)功能

默認(rèn)的功能有全屏、放大、分享、圖片切換等,有時(shí)候我們還需要圖片旋轉(zhuǎn)功能,怎么辦呢?那只能自己動(dòng)手改插件了。

第一步:添加旋轉(zhuǎn)圖標(biāo)

圖標(biāo)文件路徑:node_modules\photoswipe\dist\default-skin

原來(lái)只有前面8個(gè)圖片,后面那個(gè)稍微大一點(diǎn)的旋轉(zhuǎn)圖標(biāo)是我加上去的,當(dāng)然你也可以把尺寸設(shè)置為和原來(lái)的一樣。

第二步:添加旋轉(zhuǎn)按鈕到頁(yè)面

頁(yè)面文件路徑:node_modules\vue-preview\src\plugins\preview\preview.vue

<button class="pswp__button pswp__button--rotate" title="旋轉(zhuǎn)" @click="imgRotateFn"></button>

第三步:添加旋轉(zhuǎn)按鈕的樣式

樣式文件路徑:node_modules\photoswipe\dist\default-skin

.pswp__button--rotate {
 background-position: -176px 0;
}

第四步:實(shí)現(xiàn)旋轉(zhuǎn)方法

文件路徑:node_modules\vue-preview\src\plugins\preview\preview.vue

imgRotateFn () {
   this.angle+=90;
   let imgNode = document.getElementsByClassName('pswp__img');
   for (let i = 0; i<imgNode.length; i++) {
      imgNode[i].style.WebkitTransform = 'rotate('+this.angle+'deg)';
   }
 }

這里我只貼出了關(guān)鍵代碼,需要你自己做瀏覽器兼容,以及切換圖片時(shí),應(yīng)該將圖片角度設(shè)置為0等。

測(cè)試結(jié)果

測(cè)試沒(méi)有問(wèn)題,終于可以下班了,哈哈哈。

Tips:懶得自己動(dòng)手改插件的伙伴,可以在樓主的GitHub倉(cāng)庫(kù)下載改好后的文件,在你安裝好 vue-preview 后用“attachment”文件夾中的三個(gè)文件替換你項(xiàng)目中的對(duì)應(yīng)文件就擁有“旋轉(zhuǎn)”功能了。GitHub地址:https://github.com/xiongjun0812/vue-preview

今天就分享到這里,有問(wèn)題歡迎留言交流,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論