6

Nice Scroll に問題があります。正常に動作しますが、AJAX 画像をロードすると動作しません。興味深いことに、ウィンドウのサイズを変更したり、Firebug を開いたりすると、機能し始めます。

これを自動的に行うにはどうすればよいですか?

私は試した:

setTimeout(function(){
    $("window").trigger('resize');
}, 0);

AJAX 読み込み機能の後ですが、動作しません。

4

3 に答える 3

14

divのコンテンツが変更された場合は、nicescrollresizeメソッドを呼び出す必要があります。

$("your-div-name").getNiceScroll().resize()

画像サイズがimgタグで設定されていない場合は、すべての画像が完全に読み込まれたときにサイズ変更を呼び出す必要があることに注意してください。

于 2012-10-19T18:18:15.693 に答える
2

InuYaksa の回答に加えて、実装にアクセスできない場合は、回避策としてコンテンツ ラッパーにマウスオーバー機能を実装するだけです。

// Call resize whenever mouse
$("#scroll-area").mouseover(function() {
  $("#scroll-area").getNiceScroll().resize();
});

出典: http: //eureka.ykyuen.info/2013/05/07/jquery-nicescroll-plugin-doesnt-work-for-dynamic-content/

改善されたマウスオーバー ソリューション

//in the case of scrolling content loaded via AJAX
    $(document).on('mouseover','#scroll-area', function () {
       $(this).getNiceScroll().resize();
    });

ビューポート/ラップの使用

$(document).on('mouseover','#scroll-wrap', function () {

    var widget_wrap=$(this);
    var widget_viewport=$(this).parent();

    widget_viewport.getNiceScroll(widget_wrap).resize();

});
于 2014-10-09T13:00:46.707 に答える
0

問題を解決するには、以下のコードを使用する必要があります。ajax ロードで問題なく動作します。

$("MYSCROLLCONTAINERS").getNiceScroll().remove();
$("div[id^='ascrail']").remove();
jQuery("MYSCROLLCONTAINERS").niceScroll({
                autohidemode:false
            });

これは私にとってはうまくいきました。

于 2013-10-07T10:58:00.600 に答える