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/

相关文章:

javascript - 如何使用 ES6 Fat Arrow .filter() 对象数组

javascript - 为响应式布局隐藏 div 时如何启用菜单单击

javascript - 单击更改视频 - 在 div 内部?

javascript - 在按键保持位置时反射(reflect)可移动元素

jquery - Parsley 和 jQuery 验证比较

javascript textarea 清除回车键上的值

javascript - 在 UIWebView 上使用 Javascript 获取特定 div 类的所有内容

javascript - JS\TS - 无法在基于多个特殊字符的字符串中添加空格

javascript - 检查必填项而不对隐藏字段进行求和

javascript - ajax表单已提交但没有响应