[英]Dropdown Menu isn't Working on iPhone
當前遇到一個問題,我的導航和下拉菜單在iOS設備(特別是iPhone)上不起作用。
當用戶單擊具有子項的導航項時,我在父容器上切換了一個類,該類顯示了下拉菜單。
以下是HTML:
<div class="menu-main-menu-container">
<ul id="menu-main-menu" class="menu">
<li id="menu-item-365" class="dropdown menu-item menu-item-type-custom menu-item-object-custom menu-item-has-children menu-item-365 nav-open"><a href="#">About</a>
<ul class="sub-menu">
<li id="menu-item-44" class="menu-item menu-item-type-post_type menu-item-object-page menu-item-44"><a href="http://localhost:8888/beulah/about/im-new/">I’m New</a></li>
<li id="menu-item-166" class="menu-item menu-item-type-post_type menu-item-object-page menu-item-166"><a href="http://localhost:8888/beulah/about/membership/">Membership</a></li>
<li id="menu-item-43" class="menu-item menu-item-type-post_type menu-item-object-page menu-item-43"><a href="http://localhost:8888/beulah/about/core-values/">Core Values</a></li>
<li id="menu-item-45" class="menu-item menu-item-type-post_type menu-item-object-page menu-item-45"><a href="http://localhost:8888/beulah/about/our-history/">Our History</a></li>
<li id="menu-item-46" class="menu-item menu-item-type-post_type menu-item-object-page menu-item-46"><a href="http://localhost:8888/beulah/about/staff-directory/">Staff Directory</a></li>
</ul>
</li>
</ul>
</div>
CSS:
.sub-menu {
opacity: 0;
max-height: 0;
visibility: hidden;
transition: all 0.3s ease-in-out;
-webkit-transition: all 0.3s ease-in-out;
}
.nav-open .sub-menu {
visibility: visible;
position: relative;
opacity: 1;
padding-top: 25px;
padding-bottom: 25px;
height: inherit;
max-height: 300px;
}
JS:
$(".menu-item > a").click(function(e){
e.preventDefault();
$(this).parent().toggleClass("nav-open");
});
到目前為止,單擊該類即已應用,但在iPhone上該下拉列表無法打開。
問題是,iPad / iPhone點擊事件沒有像在桌面上那樣觸發。
您需要選擇以下任何事件:
touchstart
touchmove
touchend
touchcancel
所以在這里 :
$(".menu-item > a").bind( "touchstart" , function(e){
e.preventDefault();
$(this).parent().toggleClass("nav-open");
});
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.