1

「右スワイプ」イベントの処理中に「逆」スライド効果を作成できないようです。したがって、以下のコードは正常に機能しますが、次のページが右側ではなく左側からスライドインするように「右スワイプ」を行うとよいでしょう。私はドキュメントを検索し、「スワイプライト」に推奨さreverse: trueれるように追加しました:

$.mobile.changePage("#page"+nextPage, {transition : "slide", reverse:true});

しかし、これは望ましい効果を提供しません。どこが間違っているのか指摘できますか?

jsFiddleに次のコードがあります。

html :

<!DOCTYPE html>
<html>
<head>
    <title>jQuery Mobile Application</title>
    <link rel="stylesheet" href="http://code.jquery.com/mobile/1.0a4.1/jquery.mobile-1.0a4.1.min.css" />
    <script src="http://code.jquery.com/jquery-1.5.2.min.js"></script>
    <script src="http://code.jquery.com/mobile/1.0a4.1/jquery.mobile-1.0a4.1.min.js"></script>    
</head>

<body>
    <section id="page1" data-role="page">
        <header data-role="header"><h1>jQuery Mobile</h1></header>

        <div data-role="content" class="content">
            <p>First page!</p>
        </div>
        <footer data-role="footer"><h1>O'Reilly</h1></footer>
    </section>

    <section id="page2" data-role="page">
        <header data-role="header"><h1>jQuery Mobile</h1></header>

        <div data-role="content" class="content">
            <p>Second page!</p>
        </div>
        <footer data-role="footer"r><h1>O'Reilly</h1></footer>
    </section>

    <section id="page3" data-role="page">
        <header data-role="header"><h1>jQuery Mobile</h1></header>

        <div data-role="content" class="content">
            <p>Third page!</p>
        </div>
        <footer data-role="footer"><h1>O'Reilly</h1></footer>
    </section>    
</body>
</html>​

jQuery :

(function($) {
    var methods = {
        init : function(options) {
            var settings = {
                callback: function() {}
            };

            if ( options ) {
                $.extend( settings, options );
                }

            $(":jqmData(role='page')").each(function() {
                $(this).bind("swiperight", function() {
                    var nextPage = parseInt($(this).attr("id").split("page")[1]) - 1;
                    if (nextPage === 0) 
                        nextPage = 3;

                    $.mobile.changePage("#page"+nextPage, "slide");
                    });                        

                $(this).bind("swipeleft", function() {
                    var nextPage = parseInt($(this).attr("id").split("page")[1]) +1;
                    if (nextPage === 4) 
                        nextPage = 1;

                    $.mobile.changePage("#page"+nextPage, "slide");
                });
            })
        }
        }

    $.fn.initApp = function(method) {
        if ( methods[method] ) {
            return methods[method].apply(this, Array.prototype.slice.call(arguments, 1));
        } 
        else if ( typeof method === 'object' || ! method ) {
            return methods.init.apply( this, arguments );
        } 
        else {
            $.error( 'Method ' + method + ' does not exist' );
        }
    }
    })(jQuery);

$(document).ready(function(){
    $().initApp();
});
​
4

1 に答える 1

2

まず最初に、アルファバージョンのjQMと、参照しているjQM1.1.1のドキュメントを使用しています。最新のjQM1.2を使用するようにjsfiddleを更新しました

そして、逆スワイプ遷移の正しい構文を追加しました

$.mobile.changePage("#page"+nextPage, {
        transition: "slide",
        reverse: false
    });
});

と逆遷移

$.mobile.changePage("#page"+nextPage, {
        transition: "slide",
        reverse: true
    });
}); 
于 2012-11-21T14:10:41.403 に答える