これは、js フレームワークに依存せず、純粋な javascript で実装されるギャラリー効果です。ジェスチャータッチのスライド、写真の拡大、閉じるなどのモバイルデバイスのジェスチャー操作をサポートし、PC 上のキーボード操作もサポートします。つまり、WEB 開発者にとって必須のピクチャ ギャラリー プラグインです。
ディスプレイのレンダリングは次のとおりです:
HTML
まず、必要な CSS ファイルと js ファイルをロードします。
<link rel="stylesheet" href="css/photoswipe.css"> <link rel="stylesheet" href="css/default-skin/default-skin.css"> <script src="js/photoswipe.min.js"></script> <script src="js/photoswipe-ui-default.min.js"></script>
上記のファイルについては心配する必要はありません。Moonlight はパッケージ化されているので、ダウンロードして使用するだけです。
次に本文のHTML部分を準備します。ページ上に写真のサムネイルを用意しました。このサムネイルをクリックすると、対応する大きなアルバムがポップアップ表示されます。
HTML 構造は次のとおりです:
<div id="photos"> <img src="images/s1_m.jpg" alt="Image description" /> <p>图集</p> </div>
ここで、重要なギャラリー表示部分は、大きな画像を表示するための構造を提供します。コード内の要素: .pswp__bg、.pswp__scroll-wrap、.pswp__container、および .pswp__item は変更できないことに注意してください。
<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 構造は、ギャラリーに表示されるコンテンツ、ツール、方向ボタン、タイトルの説明、その他の要素を定義します。
JavaScript
アルバム画像コレクションをjsで定義し(もちろんdemo2のようにhtml部分で画像コレクションを定義することもできます)、各種オプションを設定してnew PhotoSwipe()を使ってphotoSwipeプラグインを呼び出します。
var openPhotoSwipe = function() { var pswpElement = document.querySelectorAll('.pswp')[0]; //定义图片集合 var items = [ { src: 'images/s1.jpg', w: 800, h: 1142 }, { src: 'images/s2.jpg', w: 800, h: 1142 } ]; var options = { history: false, focus: false, showAnimationDuration: 0, hideAnimationDuration: 0 }; var gallery = new PhotoSwipe( pswpElement, PhotoSwipeUI_Default, items, options); gallery.init(); }; //点击图集元素时触发调用openPhotoSwipe document.getElementById('photos').onclick = openPhotoSwipe;
このプラグインはモバイル プロジェクトに適用できます。詳細なオプション設定については、PhotoSwipe プロジェクトのアドレスを参照してください: https://github.com/dimsemenov/photoswipe。
上記の内容はすべて、モバイル デバイス ギャラリーをサポートするための JavaScript 実装の内容です。気に入っていただければ幸いです。