在此页面上http://kimcolemanprojects.com/我需要有一个下拉菜单,该菜单会在点击时打开,并在点击相同的锚点时再次关闭。喜欢它在这个网站上工作http://angela-moore.co.uk/
到目前为止这是我的菜单html:
<div class="left" id="nav">
<ul id="menu">
<li id="light">
<a href="lighting_video.html">Lighting + Video</a>
<ul style="display: none;">
<li><a href="django_django.html">Django Django</a></li>
<li><a href="suntrap.html">Suntrap</a></li>
</ul>
</li>
<li id="photo">
<a href="photograms.html">Photograms</a>
</li>
<li id="about">
<a class="active" href="about.html">About</a>
</li></ul>
</div><!--end nav-->
如您所见,我只需要它在一个列表项中工作。我需要帮助为此编写javascript。
因此,当在索引页面上时,用户可以看到三个链接照明+视频,摄影,关于。当用户点击照明+视频时,子菜单会在下方打开并显示更多链接。然后,如果用户再次点击照明+视频,它将再次关闭。索引页面上的每个初始三个链接都会发生同样的情况。
感谢您的帮助。
安吉拉
答案 0 :(得分:3)
很简单..
<script src="jquery.js"></script>
<div id="navigation">
<p><a href="#" id="toggle">Menu</a></p>
<ul id="menu">
<li><a href="/#" class="book-campaigns">Menu 1</a><ul>
<li><a href="#" class="lol">lol</a></li><li><a href="#" class="lol">lol2</a></li><li><a href="#" class="lol">lol</a></li><li><a href="#" class="lol">lol2</a></li>
</ul></li>
<li><a href="/#" class="book-campaigns">Menu 2</a><ul>
<li><a href="#" class="lol">lol</a></li><li><a href="#" class="lol">lol2</a></li><li><a href="#" class="lol">lol</a></li><li><a href="#" class="lol">lol2</a></li>
</ul></li>
<li><a href="/#" class="book-campaigns">Menu 3</a><ul>
<li><a href="#" class="lol">lol</a></li><li><a href="#" class="lol">lol2</a></li><li><a href="#" class="lol">lol</a></li><li><a href="#" class="lol">lol2</a></li>
</ul></li>
<li><a href="/#" class="book-campaigns">Menu 4</a><ul>
<li><a href="#" class="lol">lol</a></li><li><a href="#" class="lol">lol2</a></li><li><a href="#" class="lol">lol</a></li><li><a href="#" class="lol">lol2</a></li>
</ul></li>
这将是您的HTML容器等,在此之下您将需要您的javascript来控制隐藏和更改!如果你觉得艺术,你也可以添加一些造型!
<script>
var showMenuText = $('#toggle').text();
var hideMenuText = 'Close';
$('#navigation ul').hide();
$('#navigation ul a.active+ul').show();
hideMenu = function() {
$('#navigation ul#menu').hide();
$('#navigation').removeClass('open');
$('#toggle').text(showMenuText);
}
$('#toggle').click(function(event){
event.stopPropagation(); event.preventDefault();
$('#navigation ul#menu').toggle();
$('#navigation').toggleClass('open');
var toggleText = $('#toggle').text();
(toggleText == showMenuText) ? $(this).text(hideMenuText) : $(this).text(showMenuText);
});
$('ul#menu > li > a').click(function(event){
$this = $(this);
if( $this.hasClass('page') ) parent.location = $this.attr('href');
if( $this.hasClass('home') ) { parent.location = '/'; }
event.preventDefault(); event.stopPropagation();
if( $this.hasClass('active') ) var justclosed = true;
$('a.active').removeClass('active').next('ul').hide();
if(!justclosed) $this.addClass('active').next('ul').show();
});
</script>
这是一个简单的HTML示例,您可以按照自己喜欢的方式执行它。