javascript - 在 Safari 的 ipad/iphone 上停止传播

标签 javascript jquery

我有一个现有的悬停菜单,它在我测试过的所有浏览器和设备上都能正常运行。在此菜单中,我添加了一个用于登录名和密码的输入框,现在当使用 Safari 触摸 ipad/iphone 上的密码字段时,它会触发菜单关闭。这种行为也发生在 IE(桌面)中。

为了在 IE 中解决这个问题,我使用了这段代码:

<script type="text/javascript">
$(document).ready(function(){
  $(".subnav-container select").mouseleave(function(event){
    event.stopPropagation();
  });
});
</script>

添加此修复后,问题仍然存在于 ipad/iphone 上的 Safari 中。但是,它可以在 ipad/iphone 上的 Chrome 中正常运行。

我已尝试对移动版 Safari 进行此修复,但它不起作用:

<script type="text/javascript">
document.addEventListener('touchstart', function ( e )  {
    e.preventDefault();
    var touch = e.touches[0];
    alert(touch.pageX + " - " + touch.pageY);
}, false);
</script>

我尝试了 touchenter 、 touchleave 、 touchstart 但没有关于如何应用修复触摸屏设备问题的经验。

我的基本html如下:

    <div data-async-loaded="loaded" data-gadget="menu.gadget.MyMenuNav" data-load="preloaded">
  <nav class="menu">
    <div class="tier0">       
      <div class="shop facet nav-section" data-subnav="tab1" data-nav-tracking="tab1">
        <a href="javascript:void(0)">
          <span class="font-family--platform button-font-size--small facet-label">
            LOGIN
            <span class="arrow-down text--medium-light-grey">
            </span>
          </span>
        </a>
      </div>
    </div>

    <div class="tier1">   
       <div data-subnav="tab1" class="subnav tracking is-hidden" data-nav-tracking="tab1">
        <div class="subnav-container">
          <div class="subnav-section">
            <div class="subnav-item l-w6 visual-format">
              <form name="login" action="http://football21.myfantasyleague.com/2013/login" method="post">
              <input type="hidden" name="LEAGUE_ID" value="24779"  /> 
              <table align="center" cellspacing="1" class="homepagemodule report" id="welcome"><caption><span>Welcome</span></caption><tbody><tr><th colspan="2">Guest</th></tr>
              <tr class="oddtablerow"><td class="inputlabel">Login As:</td>
              <td><select size="1" name="FRANCHISE_ID">
              <option value="0000">Commissioner</option>
              <option value="0001">UR4BIDN</option>
              <option value="0002">NIKE TEAM B</option>
              <option value="0003">NIKE TEAM C</option>
              <option value="0004">Franchise 4</option>
              <option value="0005">Franchise 5</option>
              <option value="0006">Franchise 6</option>
              <option value="0007">Franchise 7</option>
              <option value="0008">Franchise 8</option>
              <option value="0009">Franchise 9</option>
              <option value="0010">Franchise 10</option>
              <option value="0011">TRADEA</option>
              <option value="0012">TRADEB</option>
              </select></td></tr>
              <tr class="eventablerow"><td class="inputlabel">Password:</td><td><input name="PASSWORD" type="password" size="10"  /> </td></tr>
              <tr class="oddtablerow"><td align="center" colspan="2"><input type="submit" value="Login"  /> </td></tr>
              </tbody></table></form>
            </div>                
          </div>
        </div>
      </div>          
      </div>     
  </nav>
</div>

最佳答案

script type="text/javascript">
document.addEventListener('touchend', function ( e )  {
    e.preventDefault();
e.stopPropagation();
    var touch = e.touches[0];
    alert(touch.pageX + " - " + touch.pageY);
});
</script>

关于javascript - 在 Safari 的 ipad/iphone 上停止传播,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21029660/

相关文章:

jquery - AngularJS Datatables 使用 SignalR 获取数据

javascript - 输入和输出区域之间的行高不同

javascript - 正则表达式获取模式中的字符串列表

javascript - Jquery 切换两种方法打开和关闭推送菜单

jquery - IE点击后垂直滚动条粘鼠标

javascript - bootstrap 崩溃不适用于 li

javascript - 可以使用 jquery 修改 html 字符串吗?

javascript - 如何从 AudioContext 获取麦克风数据

c# - 显示隐藏基于复选框控件的 asp 面板不起作用

javascript - Reactjs 数据结构中的表