手机端 HTML5使用photoswipe.js仿微信朋友圈图片放大效果

先来几张效果图:

点击其中一张照片可放大,可支持图片文字描述:

同时支持分享功能

支持手势放大缩小

使用js框架是photoswipephotoswipe一个图片放大插件,兼容pc和移动端,经历过多个版本的迭代且一直在不断更新,踩过的坑不知凡几,在移动端有着巨大的优势。 1、可控制多种风格如: 标题分享、全屏按钮,点击事件、是否加入字幕,背景透明等。 2、可支持移动端触摸手势兼容pc端 所有的基本手势支持:滑动下一个或上一个,拖动平移、缩放、放大或关闭,点击切换控件,双击放大或缩放。 3、分享 认的UI有一个按钮,分享链接认的链接是facebook,推特和Pinterest,但你可以通过API设置分享类型。 4、用户界面 用户界面是完全从核心脚本分离。完全可以自定义界面。photoswipe UI是响应式的,桌面、平板电脑和移动设备完全可以使用。 5、更多功能等你发现。 官网: github:

1、在官网下载photoswipe,在页面中引入

rush:xhtml;"> photoswipe.css"> photoswipe.js">

2、页面中必须加入以下代码结构(此结构是插件图片浏览必须代码,作者并没有集成到js中,所以使用者必须手动加入自己的网页中):

rush:xhtml;">

<div class="pswp__scroll-wrap">

<div class="pswpcontainer">
<div class="pswp
item">


<div class="pswpitem">

<div class="pswp
item">

<div class="pswpui pswpui--hidden">

<div class="pswp__top-bar">

<div class="pswp__counter">

<button class="pswpbutton pswpbutton--close" title="Close (Esc)">

<button class="pswpbutton pswpbutton--share" title="Share">

<button class="pswpbutton pswpbutton--fs" title="Toggle fullscreen">

<button class="pswpbutton pswpbutton--zoom" title="Zoom in/out">

<div class="pswppreloader">
<div class="pswp
preloadericn">
<div class="pswp
preloadercut">
<div class="pswp
preloader__donut">

<div class="pswpshare-modal pswpshare-modal--hidden pswpsingle-tap">
<div class="pswp
share-tooltip">

<button class="pswpbutton pswpbutton--arrow--left" title="PrevIoUs (arrow left)">

<button class="pswpbutton pswpbutton--arrow--right" title="Next (arrow right)">

<div class="pswpcaption">
<div class="pswp
caption__center">

3、需要浏览的图片加入photoswipe结构代码,这里需要注意的是 data-pswp-uid在每个相册中必须是唯一的,data-size是指定放大时图片显示的宽和高,若指定的宽高与图片不符会导致显示图片变形;目前还没找到去掉 data-size的办法,但然有时间可以找下替代办法。

rush:xhtml;">
gallery" data-pswp-uid="1">   

4、加入js代码,此代码作者也没有集成到photoswipe框架中,需要自己手动加入网页里

// 解析来自DOM元素幻灯片数据(URL,标题,大小...)
// (children of gallerySelector)
var parseThumbnailElements = function(el) {
var thumbElements = el.childNodes,numNodes = thumbElements.length,items = [],figureEl,linkEl,size,item;

for(var i = 0; i < numNodes; i++) {

figureEl = thumbElements[i]; //

element

// 仅包括元素节点
if(figureEl.nodeType !== 1) {
continue;
} 25 linkEl = figureEl.children[0]; //
element

size = 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) {
//

content
item.title = figureEl.children[1].innerHTML;
}

if(linkEl.children.length > 0) {
// 缩略图节点,检索缩略图网址
item.msrc = linkEl.children[0].getAttribute('src');
}

item.el = figureEl; // 保存链接元素 for getThumbBoundsFn
items.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;

// find root element of slide
var clickedListItem = closest(eTarget,function(el) {
return (el.tagName && el.tagName.toUpperCase() === 'FIGURE');
});

if(!clickedListItem) {
return;
}

// find index of clicked item by looping through all child nodes
// alternatively,you may define index via data- attribute
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) {
// open PhotoSwipe if valid index found
openPhotoSwipe( index,clickedGallery );
}
return false;
};

// parse picture index and gallery index from URL (#&pid=1&gid=2)
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:'新浪微博',{id:'download',label:'保存图片',url:'{{raw_image_url}}',download:true}
],// 分享按钮

// define gallery index (for URL)
galleryUID: galleryElement.getAttribute('data-pswp-uid'),getThumbBoundsFn: function(index) {
// See Options -> getThumbBoundsFn section of documentation for more info
var thumbnail = items[index].el.getElementsByTagName('img')[0],// find thumbnail
pageYScroll = window.pageYOffset || document.documentElement.scrollTop,rect = thumbnail.getBoundingClientRect();

return {x:rect.left,y:rect.top + pageYScroll,w:rect.width};
}

};

// PhotoSwipe opened from URL
if(fromURL) {
if(options.galleryPIDs) {
// parse real index when custom PIDs are used
for(var j = 0; j < items.length; j++) {
if(items[j].pid == index) {
options.index = j;
break;
}
}
} else {
// in URL indexes start from 1
options.index = parseInt(index,10) - 1;
}
} else {
options.index = parseInt(index,10);
}

// exit if index not found
if( isNaN(options.index) ) {
return;
}

if(disableAnimation) {
options.showAnimationDuration = 0;
}

// Pass data to PhotoSwipe and initialize it
gallery = new PhotoSwipe( pswpElement,PhotoSwipeUI_Default,items,options);
gallery.init();
};

// loop through all gallery elements and bind events
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;
}

// Parse URL and open gallery if it contains #&pid=3&gid=1
var hashData = photoswipeParseHash();
if(hashData.pid && hashData.gid) {
openPhotoSwipe( hashData.pid,galleryElements[ hashData.gid - 1 ],true,true );
}
};

// execute above function
initPhotoSwipeFromDOM('.my-gallery');

本文已被整理到了《》,欢迎大家学习阅读。

为大家推荐现在关注度比较高的微信小程序教程一篇:微信小程序开发教程》小编为大家精心整理的,希望喜欢。

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程之家。

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...