html简单的折叠菜单

大道至简。html+css+一个简单的JavaScript函数,实现的折叠菜单。

功能:

1.鼠标放置在菜单选项,具有变化;

2.实现一级菜单,二级菜单;

3.一级菜单收起来时,前面是“+”,展开时,前面是“-”;

效果图:

直接贴贴贴代码:

zhedie_menu.html

<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=gb2312" />
<title></title>
	<style>
	*{margin:0;padding:0;}
	
	div{
		font-size:1.5em;
		color:red; 
		background-color: #dfdfdf; 
		border: 0 solid #1892B5; 
		padding: 0px
		margin: 0px;
	}
	
	a:link,a:visited
	{
		display:block;
		color:#000000;
		background-color:#dfdfdf;
		width:200px;
		text-align:left;
		padding:4px;
		text-decoration:none;
	}
	a:hover,a:active
	{
		background-color:#dfdfdf;
		font-weight:bold;
	}
	</style>
	<link href="/static/css/style2.css" rel="stylesheet" type="text/css" />
</head>

<body>
	<script type="text/javascript">
		function show(parentid,childid) {
			var parent = document.getElementById(parentid)
			var child=document.getElementById(childid);
			if (child.style.display == "none") {     
			    child.style.display = "";
				if(parentid=="id_menu_realtime")
				{
					parent.innerHTML = "- 实时监控"
				}
				else if(parentid=="id_menu_backtest")
				{
					parent.innerHTML = "- 历史回测"
				}
			}
			else{     
			    child.style.display = "none"; 
				if(parentid=="id_menu_realtime")
				{
					parent.innerHTML = "+ 实时监控"
				}
				else if(parentid=="id_menu_backtest")
				{
					parent.innerHTML = "+ 历史回测"
				}			   
			}
		}
	</script>

	<ul id="sellist">
		<div id="realtime" style="color:blue" onclick="show('id_menu_realtime','child_realtime')" >
		<li><a id="id_menu_realtime" href="#">+ 实时监控</a></li>
		</div> 
		<div id="child_realtime" style="display:none"> 
				<li><a href="/query_bt_w" target="iframeContent">&nbsp;&nbsp;W底</a></li>
				<li><a href="/static/xxx.html" target="iframeContent">&nbsp;&nbsp;突破</a></li>
				<li><a href="/static/xxxxx.html" target="iframeContent">&nbsp;&nbsp;热点概念</a></li>
		</div>
	</ul>
		
	<ul id="sellist">
		<div id="backtest" style="color:blue" onclick="show('id_menu_backtest','child_backtest')" > 
		<li><a id="id_menu_backtest" href="#">+ 历史回测</a></li>
		</div> 
		<div id="child_backtest" style="display:none"> 
				<li><a href="/xxxx" target="iframeContent">&nbsp;&nbsp;W底</a></li>
				<li><a href="/static/xxxxxxxx.html" target="iframeContent">&nbsp;&nbsp;突破</a></li>
		</div>
	</ul>

</body>
</html>

style2.css

#sellist li
  {
	text-decoration: none;
	list-style: none;
	display:block;	
	margin:1px;
	text-align:left;
  }

 

 

  • 8
    点赞
  • 42
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用HTML和CSS实现小三角折叠菜单。具体实现步骤如下: 1. 创建HTML菜单结构,使用<ul>和<li>标签来创建菜单列表。 2. 在<li>标签中添加一个<a>标签,来定义每个菜单项的链接。 3. 在每个菜单项后添加一个<span>标签,并设置其class属性为“arrow”,来创建小三角。 4. 使用CSS来控制菜单的样式,包括菜单项和小三角的颜色、大小和位置等。 5. 使用JavaScript来实现菜单折叠和展开功能。 示例代码如下: HTML代码: ``` <ul class="menu"> <li><a href="#">菜单项1</a><span class="arrow"></span> <ul class="sub-menu"> <li><a href="#">子菜单项1</a></li> <li><a href="#">子菜单项2</a></li> <li><a href="#">子菜单项3</a></li> </ul> </li> <li><a href="#">菜单项2</a><span class="arrow"></span> <ul class="sub-menu"> <li><a href="#">子菜单项1</a></li> <li><a href="#">子菜单项2</a></li> <li><a href="#">子菜单项3</a></li> </ul> </li> <li><a href="#">菜单项3</a><span class="arrow"></span> <ul class="sub-menu"> <li><a href="#">子菜单项1</a></li> <li><a href="#">子菜单项2</a></li> <li><a href="#">子菜单项3</a></li> </ul> </li> </ul> ``` CSS代码: ``` .menu > li { position: relative; display: inline-block; padding: 5px 10px; background-color: #eee; } .menu > li > a { color: #333; text-decoration: none; } .menu > li > .arrow { position: absolute; top: 50%; right: 10px; margin-top: -3px; border-width: 6px 6px 0 6px; border-style: solid; border-color: #333 transparent transparent transparent; } .sub-menu { display: none; position: absolute; top: 100%; left: 0; z-index: 1; background-color: #eee; } .sub-menu > li { display: block; width: 100%; padding: 5px 10px; } .sub-menu > li > a { color: #333; text-decoration: none; } .menu > li:hover > .sub-menu { display: block; } ``` JavaScript代码: ``` var arrows = document.getElementsByClassName("arrow"); for (var i = 0; i < arrows.length; i++) { arrows[i].addEventListener("click", function() { var subMenu = this.parentElement.querySelector(".sub-menu"); if (subMenu.style.display == "block") { subMenu.style.display = "none"; } else { subMenu.style.display = "block"; } }); } ``` 这样就可以创建一个简单的小三角折叠菜单,点击菜单项的小三角可以展开或折叠菜单

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值