由于安卓项目涉及到h5页面嵌入,需要查看图片相册集,本来打算使用baguetteBox,但是它不太兼容手机,并且页面效果跟灵活性欠缺,后来在文档中看到PhotoSwipe,虽然开发者很懒,好多东西东西没有嵌入到插件中,但是使用效果还是不错的

官网地址  https://photoswipe.com/

首先根据他提供的git,我发现有好多没有用的文件,于是决定不使用composer,直接把有用的文件放入到项目中,可以选择压缩发布版dist,也可以选用src源码版,这里才用的是dist

首先 引入css

<link rel="stylesheet prefetch" href="photoswipe/css/photoswipe.css">
<link rel="stylesheet prefetch" href="photoswipe/css/default-skin/default-skin.css">

js放到最后

<script src="photoswipe/js/photoswipe.js"></script>
<script src="photoswipe/js/photoswipe-ui-default.min.js"></script>

开发者很懒,需要引入它的PhotoSwipe元素到DOM中

<div class="pswp" tabindex="-1" role="dialog" aria-hidden="true"><div class="pswp__bg"></div><div class="pswp__scroll-wrap"><div class="pswp__container"><div class="pswp__item"></div><div class="pswp__item"></div><div class="pswp__item"></div></div><div class="pswp__ui pswp__ui--hidden"><div class="pswp__top-bar"><div class="pswp__counter"></div><button class="pswp__button pswp__button--close" title="Close (Esc)"></button><!--<button class="pswp__button pswp__button--share" title="Share"></button>--><button class="pswp__button pswp__button--fs" title="Toggle fullscreen"></button><button class="pswp__button pswp__button--zoom" title="Zoom in/out"></button><div class="pswp__preloader"><div class="pswp__preloader__icn"><div class="pswp__preloader__cut"><div class="pswp__preloader__donut"></div></div></div></div></div><div class="pswp__share-modal pswp__share-modal--hidden pswp__single-tap"><div class="pswp__share-tooltip"></div></div><button class="pswp__button pswp__button--arrow--left" title="Previous (arrow left)"></button><button class="pswp__button pswp__button--arrow--right" title="Next (arrow right)"></button><div class="pswp__caption"><div class="pswp__caption__center"></div></div></div></div>
</div>

完整的html代码

<!DOCTYPE html>
<html>
<head><meta charset="utf-8"><meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0, user-scalable=no"><meta name="apple-touch-fullscreen" content="yes"> <!--  一会试验下是否有必要存在 --><meta name="apple-mobile-web-app-capable" content="yes"><meta name="apple-mobile-web-app-status-bar-style" content="black"><meta name="format-detection" content="telephone=no"><meta http-equiv="x-rim-auto-match" content="none"/><meta name="HandheldFriendly" content="true"/><link rel="stylesheet" href="news_css/news_1.css"><link rel="stylesheet" href="news_css/news_2.css"><link rel="stylesheet prefetch" href="photoswipe/css/photoswipe.css"><link rel="stylesheet prefetch" href="photoswipe/css/default-skin/default-skin.css"><style>* {margin: 0;padding: 0;}.clearfix::before, .clearfix::after {display: block;content: '';visibility: hidden;height: 100%;clear: both;}body {padding-top: 2%;}.my-gallery {width:96%;margin: 0 auto;}.my-gallery .img-dv {width:100%;margin-bottom: 1%;}.my-gallery .img-dv a {display:block;width:100%;text-align: center}.my-gallery .img-dv a img {width:100%;}</style>
</head>
<body>
<div class="wrapper" style="color:#333333;font-size: 15px"><header class="con_hd infoBg"><a href="?app=app_order@detail&order_id={$order_id}"  class="hd-back"></a><h2 class="hd-tit">{$data.name}</h2></header><div class="my-gallery" data-pswp-uid="1">{foreach $data['img_list'] $k=>$v}<figure><div class="img-dv"><a href="{$v['value']}" data-size="1920x1080"><img src="{$v['value']}"></a></div><figcaption style="display:none;">{$v['name']}</figcaption></figure>{/foreach}</div><div class="pswp" tabindex="-1" role="dialog" aria-hidden="true"><div class="pswp__bg"></div><div class="pswp__scroll-wrap"><div class="pswp__container"><div class="pswp__item"></div><div class="pswp__item"></div><div class="pswp__item"></div></div><div class="pswp__ui pswp__ui--hidden"><div class="pswp__top-bar"><div class="pswp__counter"></div><button class="pswp__button pswp__button--close" title="Close (Esc)"></button><!--<button class="pswp__button pswp__button--share" title="Share"></button>--><button class="pswp__button pswp__button--fs" title="Toggle fullscreen"></button><button class="pswp__button pswp__button--zoom" title="Zoom in/out"></button><div class="pswp__preloader"><div class="pswp__preloader__icn"><div class="pswp__preloader__cut"><div class="pswp__preloader__donut"></div></div></div></div></div><div class="pswp__share-modal pswp__share-modal--hidden pswp__single-tap"><div class="pswp__share-tooltip"></div></div><button class="pswp__button pswp__button--arrow--left" title="Previous (arrow left)"></button><button class="pswp__button pswp__button--arrow--right" title="Next (arrow right)"></button><div class="pswp__caption"><div class="pswp__caption__center"></div></div></div></div></div>
</body>
<script src="photoswipe/js/photoswipe.js"></script>
<script src="photoswipe/js/photoswipe-ui-default.min.js"></script>
<script type="text/javascript">var initPhotoSwipeFromDOM = function(gallerySelector) {// 解析来自DOM元素幻灯片数据(URL,标题,大小...)var parseThumbnailElements = function(el) {var thumbElements = el.childNodes,numNodes = thumbElements.length,items = [],figureEl,linkEl,size,item,divEl;for(var i = 0; i < numNodes; i++) {figureEl = thumbElements[i]; // <figure> element// 仅包括元素节点if(figureEl.nodeType !== 1) {continue;}divEl = figureEl.children[0];linkEl = divEl.children[0]; // <a> elementsize = linkEl.getAttribute('data-size').split('x');// 创建幻灯片对象item = {src: linkEl.getAttribute('href'),w: parseInt(size[0], 10),h: parseInt(size[1], 10)};if(figureEl.children.length > 1) {item.title = figureEl.children[1].innerHTML;}if(linkEl.children.length > 0) {// <img> 缩略图节点, 检索缩略图网址item.msrc = linkEl.children[0].getAttribute('src');}item.el = figureEl; // 保存链接元素 for getThumbBoundsFnitems.push(item);}return items;};// 查找最近的父节点var closest = function closest(el, fn) {return el && ( fn(el) ? el : closest(el.parentNode, fn) );};// 当用户点击缩略图触发var onThumbnailsClick = function(e) {e = e || window.event;e.preventDefault ? e.preventDefault() : e.returnValue = false;var eTarget = e.target || e.srcElement;var clickedListItem = closest(eTarget, function(el) {return (el.tagName && el.tagName.toUpperCase() === 'FIGURE');});if(!clickedListItem) {return;}var clickedGallery = clickedListItem.parentNode,childNodes = clickedListItem.parentNode.childNodes,numChildNodes = childNodes.length,nodeIndex = 0,index;for (var i = 0; i < numChildNodes; i++) {if(childNodes[i].nodeType !== 1) {continue;}if(childNodes[i] === clickedListItem) {index = nodeIndex;break;}nodeIndex++;}if(index >= 0) {openPhotoSwipe( index, clickedGallery );}return false;};var photoswipeParseHash = function() {var hash = window.location.hash.substring(1),params = {};if(hash.length < 5) {return params;}var vars = hash.split('&');for (var i = 0; i < vars.length; i++) {if(!vars[i]) {continue;}var pair = vars[i].split('=');if(pair.length < 2) {continue;}params[pair[0]] = pair[1];}if(params.gid) {params.gid = parseInt(params.gid, 10);}return params;};var openPhotoSwipe = function(index, galleryElement, disableAnimation, fromURL) {var pswpElement = document.querySelectorAll('.pswp')[0],gallery,options,items;items = parseThumbnailElements(galleryElement);// 这里可以定义参数options = {barsSize: {top: 100,bottom: 100},fullscreenEl : false,shareButtons: [{id:'wechat', label:'分享微信', url:'#'},{id:'weibo', label:'新浪微博', url:'#'},{id:'download', label:'保存图片', url:'{{raw_image_url}}', download:true}],galleryUID: galleryElement.getAttribute('data-pswp-uid'),getThumbBoundsFn: function(index) {var thumbnail = items[index].el.getElementsByTagName('img')[0], // find thumbnailpageYScroll = window.pageYOffset || document.documentElement.scrollTop,rect = thumbnail.getBoundingClientRect();return {x:rect.left, y:rect.top + pageYScroll, w:rect.width};}};if(fromURL) {if(options.galleryPIDs) {for(var j = 0; j < items.length; j++) {if(items[j].pid == index) {options.index = j;break;}}} else {options.index = parseInt(index, 10) - 1;}} else {options.index = parseInt(index, 10);}if( isNaN(options.index) ) {return;}if(disableAnimation) {options.showAnimationDuration = 0;}gallery = new PhotoSwipe( pswpElement, PhotoSwipeUI_Default, items, options);gallery.init();};var galleryElements = document.querySelectorAll( gallerySelector );for(var i = 0, l = galleryElements.length; i < l; i++) {galleryElements[i].setAttribute('data-pswp-uid', i+1);galleryElements[i].onclick = onThumbnailsClick;}var hashData = photoswipeParseHash();if(hashData.pid && hashData.gid) {openPhotoSwipe( hashData.pid ,  galleryElements[ hashData.gid - 1 ], true, true );}};initPhotoSwipeFromDOM('.my-gallery');
</script></html>

就可以使用了

文件和DOM都准备好之后,使用js来调用PhotoSwipe:

var pswpElement = document.querySelectorAll('.pswp')[0];var items = [{src: 'https://placekitten.com/600/400',w: 600,h: 400},{src: 'https://placekitten.com/1200/900',w: 1200,h: 900}
];var options = {index: 0 // start at first slide
};var gallery = new PhotoSwipe( pswpElement, PhotoSwipeUI_Default, items, options);
gallery.init();

很显然,pswpElement是指定位当前图片展示区域的元素,PhotoSwipeUI_Default是UI样式,items是滑动图片组,数组形式,options是选项设置。

通过new PhotoSwipe()就可调用了。

选项设置options

PhotoSwipe提供了丰富的选项设置,可以满足各种开发需求。以下列举一些常用的选项:

index:开始的滑块(图片),必须为数字,默认0(第一张)

showHideOpacity:当调用时是否展示透明度和比例变化动画,默认false。

showAnimationDuration:展示动画过渡时间,默认333,数字。

hideAnimationDuration:隐藏动画过渡间隔时间,默认333,数字。

maxSpreadZoom:最大放大倍数。

loop:是否循环展示图片,当左右滑动图片时。

closeOnScroll:在页面上滚动关闭图集, 仅适用于没有硬件触摸支持的设备。

escKey:是否可以使用Esc键关闭图集,默认true。

arrowKeys:是否可以使用左右方向键导航切换,默认true。

history:是否使用history模式,默认true,历史记录模式支持url返回。

galleryUID:当多个图集时,用来表示某个图集,默认1,数字,URL会变成http://example.com/#&gid=1&pid=2

galleryPIDs:表示某一张图片,配合图集galleryUID一起使用。

preload:预加载,数组,默认[1,1],是指在切换图片时,预先懒加载前后图片的张数,不能小于1。

API方法

PhotoSwipe也提供了许多方法调用,以下方法有可能你会用得到:

var pswp = new PhotoSwipe( /* ... */ );pswp.init(); //初始化
pswp.goTo(index); //跳到第几张图
pswp.next(); //下一张
pswp.prev(); //上一张
pswp.close(); //关闭图集
pswp.destroy(); //关闭图集后销毁图集// 动态添加图片
pswp.items.push({src: "path/to/image.jpg", w:1200,h:500
});

photoswipe 移动端PC端兼容图片相册预览相关推荐

  1. UC电脑端PC端浏览器下载,UC浏览器凉了?

    近期从UC浏览器的官网找不到UC浏览器的PC端没有了 而官网只有安卓端和iOS版本了 阿里官方的客服也回复说暂时不考虑开发UC浏览器电脑端了 百度贴吧也有感觉很可惜的感觉 而今天给大家带来的就是UC浏 ...

  2. 多终端登录,只保留一个移动端+PC端同时在线

    大家好,我是入错行的bug猫.(http://blog.csdn.net/qq_41399429,谢绝转载) 今天突然有小伙伴在群里问bug猫,多终端登录怎么搞. bug猫说,不知道百度的程序猿不是好 ...

  3. Vue 移动端 previewer实现图片放大预览

    简述 本文主要讲述,vue在手机移动端如何实现对小图进行放大查看预览.类似于朋友圈的照片查看. 可用工具 1.npm安装,npm i vue-preview -S 2.使用一些Vue的UI组件框架自带 ...

  4. uni-app移动端-H5-微信小程序在线预览pdf,图片,视频

    封装了一个插件,可直接导入hbuilderx查看使用: 插件地址:uni-app移动端-H5-微信小程序在线预览pdf,图片,视频 <template><view class=&qu ...

  5. 安卓端调用相机拍照返回并预览---清晰原图

    安卓端调用相机拍照并返回预览图片 一.demo预览 二.xml代码和activity简单代码描述. 三.老规矩再来写几个转换工具方法 继之前写的安卓调用相机拍照返回预览,如果对于画质要求不高的话可以考 ...

  6. js+java 实现图片在线预览功能

    本博客主要描述如何用JavaScript+java实现图片的预览功能,其实要点还是需要服务端的流. (一)功能描述 点击页面的 [预览] 查看已经上传的或者在服务器中存在的图片. (二)实现原理 使用 ...

  7. vue本地上传并预览php,vue.js 实现图片本地预览 裁剪 压缩 上传功能

    以下代码涉及 Vue 2.0 及 ES6 语法. 目标 纯 javascrpit 实现,兼容ie9及以上浏览器,在本地做好文件格式.长宽.大小的检测,减少浏览器交互. 现实是残酷的,为了兼容Ie9 还 ...

  8. javascript显示本地服务器图片,JavaScript图片本地预览功能的实现方法

    这篇文章主要介绍了JavaScript实现图片本地预览功能,针对非IE浏览器的HTML5滤镜功能及IE浏览器的相关组件功能实现不上传至服务器预览本地图片的效果,需要的朋友可以参考下 本文实例讲述了Ja ...

  9. 微信小程序选择图片和预览图片

    作者>:燕潇洒 视频中,老师也是看着官方文档,为学生们讲解,微信提供了系统的方法来选择图片. wx.chooseImage({}) 此方法是用来选择图片的方法,具体使用如下: data: {av ...

最新文章

  1. Vista OS 中添加网络中的非Vista OS共享的打印机
  2. leetcode 293.Flip Game(lintcode 914) 、294.Flip Game II(lintcode 913)
  3. GIS输出PDF为什么标注有问题
  4. Gateway网关-路由的过滤器配置
  5. Nhibernate 过长的字符串报错 dehydration property
  6. Cannot re-initialize CUDA in forked subprocess. To use CUDA with multiprocessing, you
  7. 上传一个 游戏server架构图
  8. 后缀的形容词_玩转英语词汇-词汇策略之形容词后缀
  9. python字典更改元素_python – 返回带有一个已更改元素的字典
  10. HTML的DOM和浏览器的BOM
  11. php mysql切换版本5.7_phpstudy里升级mysql版本到5.7
  12. SuperMap.IS.AjaxScript之常用功能实现研究及使用
  13. SharePoint【ECMAScript对象模型系列】-- 07. 获取和修改List的Lookup字段
  14. 即时通讯工具:Output Messenger Server
  15. 入职直接给事业编, 90万补贴+50万科启,重庆高校
  16. 使用metasploit制作钓鱼网站——browser autopwn攻击
  17. Pearson相关系数公式的四种形式及Python代码实现
  18. STM32中 利用PWM控制步进电机,ARR与PSC值的设定
  19. Boom 3D环绕音效软件免费安装使用教程
  20. excel任意单元格中自动插入页码和总页数

热门文章

  1. Win10 Chinese输入法修复/note
  2. iOS app测试版发布方案TestFlight
  3. Markdown格式文档图片设置居中
  4. 超链接标签 a (锚点链接)
  5. ping android模拟器,Android模拟器之间的网络通信及Ping主机
  6. 计算机功能及部件ppt,《计算机逻辑部件》PPT课件.ppt
  7. 最窄770px最宽1024px经典布局
  8. 电口以太网物理层一致性测试原理与过程
  9. Pytorch1.1.0 入门 自定义op(python)
  10. PS动作一键设计数字科技未来海报效果