gpt4 book ai didi

javascript - 带悬停的 CSS 动态导航 - 如何让它在 iOS Safari 中工作?

转载 作者:可可西里 更新时间:2023-11-01 03:29:49 24 4
gpt4 key购买 nike

在我的站点中,我使用纯 CSS 动态菜单。这在桌面浏览器中没有问题,但在 iOS(iphone、ipad 等)上却不行,因为触摸界面不支持 :hover 选择器。

我的问题是:在 iOS 上支持此功能的最佳方式是什么? (理想情况下,通过使用一些 CSS 或 Javascript 来修补现有代码,而不是仅仅为了支持 iOS 而将整个事情都做一遍)

我的 html 看起来像这样

<ul id="nav"> 
<li>
Item 1
<ul>
<li><a href=''>sub nav 1.1</a></li>
<li><a href=''>sub nav 1.2</a></li>
</ul>
</li>
<li>
Item 2
<ul>
<li><a href=''>sub nav 2.1</a></li>
<li><a href=''>sub nav 2.2</a></li>
</ul>
</li>
<li>
Item 3
<ul>
<li><a href=''>sub nav 3.1</a></li>
<li><a href=''>sub nav 3.2</a></li>
</ul>
</li>
</ul> ​​​​​

CSS 是这样的

#nav li {
float:left;
padding:0 15px;
}

#nav li ul {
position: absolute;
width: 10em;
left: -999em;
margin-left: -10px;
}

#nav li:hover ul {
left: auto;
}

我在这里做了一个 jsfiddle:http://jsfiddle.net/NuTz4/

最佳答案

查看这篇文章,也许它是适合您的解决方案;)

http://www.usabilitypost.com/2010/05/12/css-hover-controls-on-iphone/

也是JS解决方案,取自:http://www.evotech.net/blog/2008/12/hover-pseudoclass-for-the-iphone/

var nav = document.getElementById('nav');
var els= nav.getElementsByTagName('li');
for(var i = 0; i < els.length; i++){
els[i].addEventListener('touchstart', function(){this.className = "hover";}, false);
els[i].addEventListener('touchend', function(){this.className = "";}, false);
}

在 jQuery 中:

$('#nav li').bind('touchstart', function(){
$(this).addClass('hover');
}).bind('touchend', function(){
$(this).removeClass('hover');
});

CSS:

li:hover, li.hover { /* whatever your hover effect is */ }

关于javascript - 带悬停的 CSS 动态导航 - 如何让它在 iOS Safari 中工作?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/3501586/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com