我正在尝试创建一个针对移动设备进行优化的导航。
<nav id="nav-content" class="nav-main">
<ul>
<li>
<a href="">about</a>
</li>
<li>
<a class="parent-link">production</a>
<ul class="sub-menu">
<li><a href="">workshops</a></li>
<li><a href="">shows</a></li>
<li><a href="">greenlite</a></li>
</ul>
</li>
<li><a href="">watch</a></li>
<li><a id="link-logo" href="index.html"><div id="logo"></div></a></li>
<li>
<a class="parent-link">members</a>
<ul class="sub-menu">
<li><a href="">current</a></li>
<li><a href="">prospective</a></li>
</ul>
</li>
<li>
<a class="parent-link">postings</a>
<ul class="sub-menu">
<li><a href="">jobs</a></li>
<li><a href="">auditions</a></li>
</ul>
</li>
<li>
<a class="parent-link">contact</a>
<ul class="sub-menu">
<li><a href="">team</a></li>
<li><a href="">advertise</a></li>
<li><a href="">suggestions</a></li>
</ul>
</li>
</ul>
</nav>
<nav id="nav-mobile-header"><a href="index.html"><div id="logo-small"></div></a><div id="nav-trigger">
☰
</div></nav>
当窗口小于 1000 像素时,导航类从 .nav-main 正确更改为 .nav-mobile。
$(document).ready(function()
{
$(function () {
$(window).resize(function () {
if ($(window).width() <= 1000)
{
$('#nav-content').removeClass('nav-main').addClass('nav-mobile');
}
else
{
$('#nav-content').removeClass('nav-mobile').addClass('nav-main');
if ($('#wrap').hasClass('to-left'))
{
$('#wrap').removeClass('to-left');
}
}
}).resize();
});
});
当导航类为 .nav-main 时,我在悬停时设置了一个向下滑动菜单。但是,当 .nav-mobile 是导航的类时,仍然会触发此查询。为什么会这样?即使更改了类,为什么仍然有链接的事件侦听器?
$(document).ready(function()
{
var slideTime = 300;
$('.nav-main li').hover(function () //why does this still work for .nav-mobile?
{
$('.sub-menu', this).stop().slideDown(slideTime);
$('.parent-link', this).css('color', '#555');
},function ()
{
$('.sub-menu', this).stop().slideUp(slideTime);
$('.parent-link', this).attr('style', '');
});
});
感谢任何帮助,我对 jQuery 和 SO 还是比较陌生。