Skip to content

9ji/vue-photoswipe-mobile

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

16 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

vue-photoswipe-mobile

基于photoswipe的vue图片查看器

示例

地址

说明

1、只支持移动端,不支持pc,解决了很多手势问题,所以割舍了pc的支持。

2、支持slot扩展 topbar 和 底栏caption

3、取消了photoswipe图片需设定尺寸的要求

4、解决了photoswipe长按图片浏览器无法弹出保存动作的问题

5、解决了photoswipe连续双击放大缩小图片导致放大过程终止的问题

6、强行关掉原photoswipe参数

captionEl =  false    // 不用原插件的底栏
fullscreenEl = false  // mobile不用全屏
shareEl = false       // 关掉了分享
arrowEl = false       // 关掉了左右箭头
zoomEl = false        // 关掉了放大镜按钮

7、存在slot的topbar时,强行关掉了以下参数

preloaderEl = false // 预加载的loading图
counterEl = false  //  current/图片数量,需要自己在topbar实现,看下面
closeEl = false // 关闭按钮,需要自己在topbar实现,看下面

安装

npm install vue-photoswipe-mobile --save

引入

import previewer from 'vue-photoswipe-mobile'

模块没打包成umd,需要的话自己拉代码去打包吧。都2020年了。

使用

参数

index

需要显示的图片索引 必传

list

图片列表[{src:'xxx'},{src:'xxx'}] 必传

options

参照photoswipe 不必传 options.addCaptionHTMLFn 被去掉了,用slot去插入caption吧

函数调用方式

previewer.open(index, list, options)

函数调用时用open

组件调用方式

局部注册组件

components:{
  previewer
}

模板写法 使用slot扩展底栏和头部

list : [{src:'xxx',captionData:{}},{src:'xxx',captionData:{}}]
<previewer :list="list" ref="previewer" :options="{tapToClose:false}">
      <template slot-scope="{current}" slot="topbar">
        <div>
          <span>{{current+1}} of {{list.length}}</span>
          <a @click="$refs.previewer.close()">关闭</a>
        </div>
      </template>
      <template slot-scope="{current}" slot="caption">
        <some-caption :captionData="list[current].captionData"></some-caption>
      </template>
    </previewer>
    // 组件调用时用show
    this.$refs.previewer.show(index)

About

No description, website, or topics provided.

Resources

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published