質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

ただいまの
回答率

90.04%

masonryがajaxでオートロードした際に2ページ目以降適応されない

受付中

回答 3

投稿 編集

  • 評価
  • クリップ 0
  • VIEW 2,365
退会済みユーザー

退会済みユーザー

masonryをajaxでページングした際に
2ページ目以降(ページ遷移なし)でmasonryが効きない事態に陥ってます。

「もっと見る」ボタンはなくinview.jsを使用して
オートロードするようになってます。

最初にnextTickを使用してみましたが
高さの計算が上手くいかず重なってしまいました。

var deferred = ajaxPagingLoaderReady(options, loaderEl, 'auto', state, self, resultKey);

            deferred.done(function() {
                var units = $('.unit').not('.masonried');
                Vue.nextTick(function() {
                    new Masonry('.unitList', {
                        columnWidth: 360,
                        isFitWidth: true,
                        itemSelector: '.unit',
                        gutter: 20,
                        isAnimatedFromBottom: true
                    });
                    units.each(function() {
                        $(this).addClass('masonried');
                    });
                });
            }).fail(function() {
                console.log('fail');
            });

その後、setIntervalを使用したコードに書き換えてみました。
最初の読み込みでは問題なく動いてるのですが
2回目の読み込みからmasonryが適応されません。

var deferred = ajaxPagingLoaderReady(options, loaderEl, 'auto', state, self, resultKey);

            deferred.done(function() {
                var units = $('.unit').not('.masonried');
                var renderMasonry = function() {
                    new Masonry('.unitList', {
                        columnWidth: 360,
                        isFitWidth: true,
                        itemSelector: '.unit',
                        gutter: 20,
                        isAnimatedFromBottom: true
                    });
                    units.each(function() {
                        $(this).addClass('masonried');
                    });
                };

                var interval = setInterval(function() {
                    console.log($('.unitList').height());
                    if ($('.unitList').height() > 0) {
                        renderMasonry();
                        clearInterval(interval);
                    }
                }, 200);
            }).fail(function() {
                console.log('fail');
            });

検索をしてみたところ
imagesLoadedを使うといいと見たので試してみました。

var deferred = ajaxPagingLoaderReady(options, loaderEl, 'auto', state, self, resultKey);

            deferred.done(function() {
                var units = $('.unit').not('.masonried');
                imagesLoaded('.unitList',function() {
                    new Masonry('.unitList', {
                        columnWidth: 360,
                        isFitWidth: true,
                        itemSelector: '.unit',
                        gutter: 20,
                        isAnimatedFromBottom: true
                    });
                    units.each(function() {
                        $(this).addClass('masonried');
                    });
                });
            }).fail(function() {
                console.log('fail');
            });

最初と同じく重なってしまう状況になってます。

ご教示いただけますと幸いです。

【追記】
imgタグにwidth, heightを指定する解決方法もありましたが
JSONから取得しており幅高さは統一されておりません。

  • 気になる質問をクリップする

    クリップした質問は、後からいつでもマイページで確認できます。

    またクリップした質問に回答があった際、通知やメールを受け取ることができます。

    クリップを取り消します

  • 良い質問の評価を上げる

    以下のような質問は評価を上げましょう

    • 質問内容が明確
    • 自分も答えを知りたい
    • 質問者以外のユーザにも役立つ

    評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。

    質問の評価を上げたことを取り消します

  • 評価を下げられる数の上限に達しました

    評価を下げることができません

    • 1日5回まで評価を下げられます
    • 1日に1ユーザに対して2回まで評価を下げられます

    質問の評価を下げる

    teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。

    • プログラミングに関係のない質問
    • やってほしいことだけを記載した丸投げの質問
    • 問題・課題が含まれていない質問
    • 意図的に内容が抹消された質問
    • 広告と受け取られるような投稿

    評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。

    質問の評価を下げたことを取り消します

    この機能は開放されていません

    評価を下げる条件を満たしてません

    評価を下げる理由を選択してください

    詳細な説明はこちら

    上記に当てはまらず、質問内容が明確になっていない質問には「情報の追加・修正依頼」機能からコメントをしてください。

    質問の評価を下げる機能の利用条件

    この機能を利用するためには、以下の事項を行う必要があります。

回答 3

+2

ロード時にmasonryを一度実行します。
その後、ajax成功時(DOM更新時)にはreloadItemsを実行するだけで良いと思います。
masonriedクラスの付与も不要です。

公式ドキュメント
http://masonry.desandro.com/methods.html#reloaditems

var deferred = ajaxPagingLoaderReady(options, loaderEl, 'auto', state, self, resultKey);
var masonry;

deferred.done(function() {
  var renderMasonry = function() {
    masonry = new Masonry('.unitList', {
      columnWidth: 360,
      isFitWidth: true,
      itemSelector: '.unit',
      gutter: 20,
      isAnimatedFromBottom: true
    });
  };

  renderMasonry();
}).fail(function() {
  console.log('fail');
});


```

投稿

編集

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2016/02/04 20:20

    ご回答ありがとうございます!

    教えていただいたコードを試したところ
    ローダーがぐるぐる回ったままになり
    masonryが実行されるまでに至っていないようでした。
    (エラーは出ておらず。)

    コードを元に改変などしてみたのですが
    なかなか動かず...。

    また何かお気づきの点がありましたら
    ご回答いただけますと幸いです!

    キャンセル

  • 2016/02/05 10:37 編集

    回答のコードを修正しました。
    こちらだといかがでしょうか?

    キャンセル

+1

appended というメソッドがあるようですね。

Adds and lays out newly appended item elements to the end of the layout.
Masonry · Methods

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

  • 2016/02/04 20:13

    ご回答ありがとうございます!
    appendedを調べながら少し試してみました。

    2ページがオートロードされるタイミングで
    appendedしてあげるのは想像できるのですが
    なかなか実現できず...。

    もし宜しければ
    もう少し詳しいコードを教えていただけますと幸いです!

    キャンセル

+1

もう解決済みでしょうか?
私も同じ問題にあたり、以下の手順で解決しました。
jqueryでの実装ですので、コードが違いますが参考までに。

$.ajax({
  dataType: 'html',
  url: 'example.php'
})
.done(function(data) {
  $('#target').append(data);
  var $grid = $('#target').imagesLoaded( function() {
    $grid.masonry('appended', $(data));
    $grid.masonry('reloadItems');
    $grid.masonry('layout');
  });
});

投稿

  • 回答の評価を上げる

    以下のような回答は評価を上げましょう

    • 正しい回答
    • わかりやすい回答
    • ためになる回答

    評価が高い回答ほどページの上位に表示されます。

  • 回答の評価を下げる

    下記のような回答は推奨されていません。

    • 間違っている回答
    • 質問の回答になっていない投稿
    • スパムや攻撃的な表現を用いた投稿

    評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。

15分調べてもわからないことは、teratailで質問しよう!

  • ただいまの回答率 90.04%
  • 質問をまとめることで、思考を整理して素早く解決
  • テンプレート機能で、簡単に質問をまとめられる