11

jquery masonryと画像レイアウトで私が抱えている問題を示すこのテンプレートを見つけました。この Twitter ブートストラップ テンプレートページを見てください。

ページが初めて読み込まれると、ページの更新またはサイズ変更が行われるまで、すべての画像が互いに積み重ねられます。その後、画像は正しく表示されます。

同じ問題を抱えているHTMLとjQueryは次のとおりです。

HTML

<div class="gallery-masonry masonry" style="position: relative; min-height:100px; height: auto;">
  <div id="loading">Loading ...</div>                            
</div>

jQuery

$.post("functions/photo_functions.php", { f: 'getallphotos'}, function(data) {

  $('#loading').hide();

    if(data) {  
      $.each(data.images, function(i, image) {
        var img_block = '<div class="item masonry-brick" style="position: absolute; top: 0px; left: 0px;">' +
        '<a href="#" class="thumbnail"><img src="'+image.url+'" alt=""></a>' +
        '<div class="actions">' +
        '<a title="" href="#" class="tip-top" data-original-title="Edit"><i class="icon-pencil icon-white"></i></a>' +
        '<a title="" href="#" class="tip-top" data-original-title="Remove"><i class="icon-remove icon-white"></i></a>' +
        '</div>' +
        '</div>';

        $(".gallery-masonry").append(img_block);
          });

        $('.gallery-masonry').masonry({
          itemSelector: '.item',
          isAnimated: true,
          isFitWidth: true
        });             
      }

    }, "json");

なぜこれが起こっているのか、どうすれば修正できるのでしょうか?

4

2 に答える 2

16

すべての画像がロードされた後、imagesLoaded() を使用してメイソンリーをトリガーします。(imagesLoaded()スクリプトhttp://github.com/desandro/imagesloadedによって提供されます。)

$('.gallery-masonry').imagesLoaded( function(){
  $('.gallery-masonry').masonry({
   itemSelector: '.item',
   isAnimated: true,
   isFitWidth: true
  });
});
于 2013-05-06T02:33:42.130 に答える
5

受け入れられた回答には手順がありません。そこで、ここにステップバイステップがあります。

  1. imagesloadedリポジトリに移動し、https://github.com/desandro/imagesloaded/blob/master/imagesloaded.pkgd.min.jsで縮小版をダウンロードします。
  2. そのライブラリをプロジェクトに追加します。
  3. ページの下部でファイルを呼び出します

```[javascript ファイルへのパスを調整します]

<script src="/js/masonry.pkgd.min.js"></script>
<script src="/js/imagesloaded.pkgd.min.js"></script>

<script>
  $('.gallery-masonry').imagesLoaded( function(){
    $('.gallery-masonry').masonry({
     itemSelector: '.item',
     isAnimated: true,
     isFitWidth: true
    });
  });
</script>
于 2014-07-10T19:06:06.560 に答える