在Safari浏览器上的iPad/iPhone上使用stopPropagation

3

我有一个现成的悬停菜单,在我测试过的所有浏览器和设备上都能很好地工作。在这个菜单里,我添加了一个用于登录和密码的输入框。现在,当使用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>

请在 JSFiddle 上包含您的工作代码链接。您没有包含其他人能够复制问题所需的所有代码。 - Larz
2个回答

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

1
我找到了 iPhone 问题的解决方案! 你需要直接在 DOM 元素上设置“Propagation”。 其余的 JS 可以按照通常的方式编写。 示例:
<body>
   <a href="google.com"> Parent that should remain unaffected <br><br>
      
      <div onclick="function(e){e.preventDefault(); e.stopPropagation();};"> 
         Clicking here will not activate the "A" tag 
      </div>
   
   </a>
</body>

<script>
   $('div').click(function(){
      window.location.href = "samborsky.pro";
   });
</script>

网页内容由stack overflow 提供, 点击上面的
可以查看英文原文,
原文链接