5

jQtouch と iScroll を使用してモバイル Web サイトを作成しています。

iScrollで複数のスクロール可能な領域を取得したくありませんが、iScrollで機能するのはリストだけです...

私はこれで試しました:

var scroll1, scroll2;
function loaded() {
   scroll1 = new iScroll('wrapper');
   scroll2 = new iScroll('list_wrapper');
}

しかし、運がなければ。誰もが機能している解決策を持っていますか?

私のHTML:

<div id="wrapper">
    <ul>
        <li><a href="#">Test</a></li>
    </ul>
</div>

<div id="list_wrapper">
    <ul>
        <li><a href="#">Test</a></li>
    </ul>
</div>
4

4 に答える 4

2

私はこのアプローチを使用しています。

HTML:

<div class="carousel" id="alt-indie">
    <div class="scroller">
        <ul>
            <li></li>
            // etc
        </ul>
    </div>
</div>

JS:

$('.carousel').each(function (index) {
    new iScroll($(this).attr('id'), { /* options */ });
});

したがって、「カルーセル」のクラスを持つものはすべてスライダーになります。

于 2012-06-01T14:37:51.730 に答える
0
var scroll1, scroll2;

$("#you_might_like_index").live("pageshow", function() {

  setTimeout(function(){scroll1 = new iScroll('wrapper');}, 0);
  setTimeout(function(){scroll2 = new iScroll('list_wrapper');}, 0);
});

<div data-role="page" id="you_might_like_index">

  <div id="wrapper">
    <div id="scroller">
      <ul>
        <li><a href="#">Test</a></li>
      </ul>
    </div>
  </div>


  <div id="list_wrapper">
    <div id="scroller">
      <ul>
        <li><a href="#">Test</a></li>
      </ul>
    </div>
  </div>

</div>
于 2012-04-18T03:20:49.300 に答える
0

あなたのhtmlは正しいようです、

「ロード済み」関数が wel として呼び出されていることを確認してください。

このようなもの:

document.addEventListener('DOMContentLoaded', loaded, false);

それが役立つことを願っています。

于 2012-04-08T10:12:47.290 に答える
0

この答えは少し遅れるかもしれません...しかし、私は同じ問題に悩まされていたので、ここに私の解決策があります。注: このソリューションには jquery が必要ですが、とにかく使用しています。

スクリプト部分:

function iscroller_init () {
    var iscroller = $('.iscroller');
    iscroller.each(function(index){
        $(this).addClass('iscroller'+index).attr('iscroller_id','iscroller'+index);
        var tmpfnc = new Function('var myScroll'+index);
        tmpfnc();
        var tmpfnc = new Function('myScroll'+index+' = new IScroll(\'.iscroller'+index+'\', { mouseWheel: true });');
        tmpfnc();
    });
}

function iscroller_reinit (el) {
    var el = $(el);
    var iscroller = $('.iscroller');
    var i = iscroller.index(el);
    var tmpfnc = new Function('var myScroll'+i+' = new IScroll(\'.iscroller'+i+'\', { mouseWheel: true });');
    tmpfnc();
}

document.addEventListener('touchmove', function (e) { e.preventDefault(); }, false);

$(document).ready(function(){
    if ($('.iscroller').length > 0) iscroller_init ();
});

html:

<div class="scrollholder fl">
    <div class="iscroller">
        <div class="scroller">
            <ul>
                <li>Pretty row 1</li>
                <li>Pretty row 2</li>
                <li>Pretty row 3</li>
                <li>Pretty row 4</li>
                .....
                <li>Pretty row 47</li>
                <li>Pretty row 48</li>
                <li>Pretty row 49</li>
                <li>Pretty row 50</li>
            </ul>
        </div>
    </div>
</div>

ここで、親<div class="scrollholder fl">は親 div であり、必要な場所に複数回配置できます。情報: 私の場合、クラス "fl" は css 区切りとして"float:left;"機能し、iscroll 関数には対応していません。2 番目の関数iscroller_reinit (el)は、指定された単一の iscroller を再初期化するためのもので、コンテナが ajax リクエストによってロードされた後に起動される場合があります。

于 2015-01-20T23:56:12.717 に答える