JavaScriptにてスワイプ可能なLightBox系ライブラリ「PhotoSwipe」の利用方法
あるサイトをWappalyzerで調査していた際に「PhotoSwipe」という見たことの無いJavaScriptライブラリが使用されていた。調べてみるとLightBox系ライブラリでスワイプに対応していたり、色々高機能みたい。以下にサンプルと利用方法をメモ。
サンプル
https://taitan916.info/sample/PhotoSwipe/
スライダー表示・個別表示が確認できる筈。
PhotoSwipe
GitHub
https://github.com/dimsemenov/photoswipe
公式サイト
CDN
CDNで使う場合は以下を記述する。
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/photoswipe/5.4.4/photoswipe.min.css"> <script src="https://cdnjs.cloudflare.com/ajax/libs/photoswipe/5.4.4/umd/photoswipe.umd.min.js"></script> <script src="https://cdnjs.cloudflare.com/ajax/libs/photoswipe/5.4.4/umd/photoswipe-lightbox.umd.min.js"></script>
利用方法
ソースコード
<style>
img{
width: 200px;
}
a{
text-decoration: none;
}
.gallery{
margin-bottom: 20px;
}
.title{
font-weight: bold;
}
</style>
<div id="gallery_1" class="gallery">
<div class="title">スワイプ可能(スライダー表示)</div>
<div class="img">
<a href="./img/001.jpg" data-pswp-width="400" data-pswp-height="200">
<img src="./img/001.jpg">
</a>
</div>
<div class="img">
<a href="./img/002.jpg" data-pswp-width="400" data-pswp-height="200">
<img src="./img/002.jpg">
</a>
</div>
<div class="img">
<a href="./img/003.jpg" data-pswp-width="400" data-pswp-height="200">
<img src="./img/003.jpg">
</a>
</div>
</div>
<div id="gallery_2" class="gallery">
<div class="title">スワイプ不可(個別表示)</div>
<div class="img">
<a href="./img/001.jpg" data-pswp-width="400" data-pswp-height="200">
<img src="./img/001.jpg">
</a>
</div>
<div class="img">
<a href="./img/002.jpg" data-pswp-width="400" data-pswp-height="200">
<img src="./img/002.jpg">
</a>
</div>
<div class="img">
<a href="./img/003.jpg" data-pswp-width="400" data-pswp-height="200">
<img src="./img/003.jpg">
</a>
</div>
</div>
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/photoswipe/5.4.4/photoswipe.min.css">
<script src="https://cdnjs.cloudflare.com/ajax/libs/photoswipe/5.4.4/umd/photoswipe.umd.min.js"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/photoswipe/5.4.4/umd/photoswipe-lightbox.umd.min.js"></script>
<script>
const lightbox_1 = new PhotoSwipeLightbox({
gallery: '#gallery_1',
children: 'div.img',
pswpModule: PhotoSwipe
});
lightbox_1.init();
const lightbox_2 = new PhotoSwipeLightbox({
gallery: '#gallery_2 a',
pswpModule: PhotoSwipe
});
lightbox_2.init();
</script>
所感
jQuery不要且つスワイプ可能ということでLightboxの上位互換っぽい。しばらくはこちらを試していきたいところ。
関連記事
-
-
Ajaxでプラグイン無しのファイルアップロード方法
画像ファイルを添付できて、尚且つAjaxを用いた非同期通信のフォームを作りたかっ ...
-
-
Lightboxで画像拡大時にダウンロードリンクを設置する方法
Lightboxで画像拡大時にダウンロードリンクを設置したいと要望を受けた。もち ...
-
-
ライブラリ等を使用せずファイルをドラッグ&ドロップでアップロードする方法
formにドラッグ&ドロップでファイルをアップロードする機能を実装する場 ...
-
-
Gif画像に再生ボタンを設置し、ユーザーの操作により再生⇔停止が行える「gifffer」ライブラリの利用方法
あるページにGif画像を設置し、当該画像が表示されても自動再生させず、再生ボタン ...
-
-
javascriptやjQueryで画像を書き換えても変わらない場合
けっこう前に画像をアップロードしてリアルタイムにプレビューする機能を作った時に、 ...