带有touchmove事件的jQuery Mobile

时间:2015-05-14 09:58:47

标签: jquery jquery-mobile swipe touchmove jquery-mobile-flipswitch

我正在尝试管理基本选择开关,如以下文档中所示:

http://demos.jquerymobile.com/1.4.5/flipswitch/

我的代码是:

HTML

    <div class="ui-flipswitch ui-shadow-inset ui-bar-inherit ui-corner-all ui-mini">
    <a href="#" class="ui-flipswitch-on ui-btn ui-shadow ui-btn-inherit">On</a>
    <span class="ui-flipswitch-off">Off</span>
    <select data-role="flipswitch" data-mini="true" 
name="login-memo-codice-inpt" id="login-memo-codice-inpt" class="ui-
flipswitch-input" tabindex="-1" disabled="">
    <option value="off">Off</option>
    <option value="on">On</option>
    </select>
    </div> 

JAVASCRIPT

inputManager.my_slider=function(page){
    var enableTap=false;
    var executed=false;
    var flipswitch=page.find(".ui-flipswitch");
    flipswitch.on("touchstart",function(e){
        enableTap=true;
        executed=false;
    });
    flipswitch.on("tap",function(){
        if(executed){
            return false;
        }
    });     
    flipswitch.on("touchmove",function(e){
        if(enableTap){
            enableTap=false;
            $(this).trigger("click");
            executed=true;
        }           
    });
    flipswitch.on("touchend",function(e){
        enableTap=false;
    });                     
    page.find(".ui-flipswitch-input").prop("disabled",true);
    page.find(".ui-flipswitch-input").on("touchstart focus",function(event){
        event.preventDefault();             
        $(this).blur();
        return false;
    });
    if(libs.check_current_device().ieMobile){
        flipswitch.on("mousedown",function(e){
            $(this).trigger("click");
        });
    }
};

当我从左(ON)向右(OFF)或从右(OFF)向左(ON)向上滑动时,它起作用。

我的问题是:

  1. 如果我把手指放在ON上,然后我向右滑动(OFF) 状态变为OFF然后立即返回ON;
  2. 如果我将手指放在OFF上然后向左滑动(ON),状态变为ON,然后立即返回OFF。
  3. 如何解决这个问题?

0 个答案:

没有答案