在项目中首页,颜络社,我的主页,其余用户主页4个页面都须要展现用户所发布的动态内容(相似于微信朋友圈内容),故进行封装。css
页面效果以下:vue
难点:node
a.图片展现。点击查看大图,上滑图片退出。npm
主要使用了PhotoSwipe插件。
首先使用npm在项目中安装photoswipe
npm install photoswipe
安装成功后,在对应的.vue文件中引入:
import PhotoSwipe from 'photoswipe'
import PhotoSwipeUI_Default from 'photoswipe/dist/photoswipe-ui-default'
import 'photoswipe/dist/photoswipe.css'
import 'photoswipe/dist/default-skin/default-skin.css'
复制代码
(小坑:必定要写入下面的代码内容)数组
```
<!-- PhotoSwipe插件须要的元素, 必定要有类名 pswp -->
<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>
<!-- 预览区域顶部的默认UI,能够修改 -->
<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>
```
复制代码
完成了初期准备工做,如今开始正式使用啦~bash
<div class="thumbnails my-gallery">
<figure v-for="(img, index) in item.tiebaPictureslist" :key="index" itemprop="associatedMedia" itemscope itemtype="http://schema.org/ImageObject" class="thumbnail">
<a :href="img.ptPic" itemprop="contentUrl" :data-size="img.ptPic | dataSize" v-show="img.ptPic">
<img :src="img.ptPic + '?imageView2/5/w/100/h/100'" itemprop="thumbnail" alt="" />
</a>
</figure>
</div>
复制代码
(小坑2:使用photoswipe预览图片本身的图片的数组必须保证有图片宽高,即利用七牛云图片处理技术将图片进行宽高设定)微信
接下来,就开始给须要点击放大预览的图片进行绑定预览事件啦~ui
methods: {
initPhotoSwipeFromDOM(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];
if (figureEl.nodeType !== 1) {
continue
}
linkEl = figureEl.children[0];
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) {
item.title = figureEl.children[1].innerHTML
}
if (linkEl.children.length > 0) {
item.msrc = linkEl.children[0].getAttribute('src')
}
item.el = figureEl
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
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 = {
history: false,
galleryUID: galleryElement.getAttribute('data-pswp-uid'),
getThumbBoundsFn: function(index) {
var thumbnail = items[index].el.getElementsByTagName('img')[0],
pageYScroll = 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)
}
}
},
updated() {
this.initPhotoSwipeFromDOM('.my-gallery')
}
复制代码
以上,实现图片点击查看,能够左右滑动,向上滑动退出图片查看。this