Home >Web Front-end >HTML Tutorial >用css+js实现自动伸缩导航栏_html/css_WEB-ITnose
偶然一个机会,在网上看到一篇ted公开课【让我们教孩子编程吧】里面有一个实例,说是一个小男孩制作了一个大鱼吃小鱼的游戏,他想为这个游戏做一个计分板(吃一条鱼加一分),便他在网上求教,后来被网站创作者发现后,告诉了他答案:变量。通过这个学到的知识点【变量】也许小男孩永远不会忘记。
从中可以看出,通过需求学习编程往往比为了学编程而学习编程要记得更劳并且更有价值。这也对我之后的学习以及写作产生的改变。
PS:以下代码每次只写出有更改的地方,无更改的地方不再赘述。每一部分的格式都是:效果图——思路——代码的顺序书写,目的是希望初学者可以根据效果图,辅以思路试着自己写出代码,最后再与作者的代码作比较,希望能通过这个方法明白,实现效果的方式是多种多样的,不要只局限在作者的思路中,当然最重要的是能锻炼自己编写代码的能力。
task goal_1
task goal_2
这是一个没有任何css修饰的html代码
3
无序列表:
<ul class="nav" > <li><a href="#">首 页</a></li> <li><a href="#">新闻快讯</a></li> <li><a href="#">产品展示</a></li> <li><a href="#">售后服务</a></li> <li><a href="#">联系我们</a></li> </ul>
这是导航栏默认样式,我们通过css进行初步修改
4
把浏览器默认的盒模型值,列表样式以及链接样式的默认样式取消,并且把字体颜色改成黑色。
*{margin: 0;padding: 0; font-size: 14px;} li{list-style: none;} a{text-decoration: none; color: #000;}
5
li{list-style: none;float:left;}li a{display:block;width: 100px; height: 30px;line-height: 30px; text-aligin:center; }
6
li a{display:block;width: 100px; height: 30px;line-height: 30px; background-color: #efefef; margin-left:1px;}.on,.nav li a:hover{ background-color: #f60; color: #fff;}
7
1.通过border-bottom属性制作导航栏的“脚”;
ul{height:50px; border-bottom:5px solid #f60; padding-left:20px;}li{margin-top:20px;}
8
.on,.nav li a:hover{ height: 40px; line-height: 40px; margin-top: -10px;}
以上是css部分,下面讲JavaScript。
分为两部分来写:自动伸和自动缩
9
效果:鼠标划过导航栏自动延伸。
window.onload=function(){ var aA=document.getElementsByTagName("a"); for(var i=0;i<aA.length;i++){ aA[i].onmouseover=function(){ var This=this; clearInterval(This.time);//初始化 This.time=setInterval(function(){ This.style.width=This.offsetWidth+8+"px"; if(This.offsetWidth>=150){ clearInterval(This.time) } },30); } } }
最终图片,与文章开头图片相同效果:鼠标离开导航栏自动缩到原始状态。
aA[i].onmouseout=function(){ var This = this; clearInterval(This.time);//初始化 This.time=setInterval(function(){ This.style.width=This.offsetWidth-8+"px"; if(This.offsetWidth<=100){ clearInterval(This.time); } },30); }}
<!DOCTYPE html><html><head> <meta http-equiv="Content-Type" content="text/html" charset="UTF-8"> <title>导航栏v1.0</title> <style type="text/css"> /*@group general style*/ *{margin: 0;padding: 0;font-size: 14px;} a{color: #333;text-decoration: none;} ul{ list-style: none;border-bottom: 5px solid #f60;height: 50px; padding-left: 30px; } li{ margin-top:20px; float: left;} /*@group overrides*/ .nav li a{ display: block; text-align: center; height: 30px; line-height:30px; width: 120px; background-color: #efefef; border-radius: 5px; } .nav .on,.nav li a:hover{ color: #fff; background-color: #f60; height: 40px; line-height: 40px; margin-top: -10px; } </style></head><body> <ul class="nav" > <li><a class="on" href="#">首 页</a></li> <li><a href="#">新闻快讯</a></li> <li><a href="#">产品展示</a></li> <li><a href="#">售后服务</a></li> <li><a href="#">联系我们</a></li> </ul> <script type="text/javascript"> window.onload=function(){ var aA=document.getElementsByTagName("a"); for(var i=0;i<aA.length;i++){ aA[i].onmouseover=function(){ // 设置方法停止的时机 clearInterval(this.time); // 此处this为当前a标签 var This=this; // 设置方法每30毫秒运行一次 // 其中offsetWidth:对象的可见宽度,包括本身width+padding-border // 当offsetWidth>=120时,程序停止。 This.time=setInterval(function(){ This.style.width=This.offsetWidth+8+"px"; if(This.offsetWidth>=160){ clearInterval(This.time); } },30); } aA[i].onmouseout=function(){ clearInterval(this.time);//初始清理 var This=this; This.time=setInterval(function(){ This.style.width=This.offsetWidth-8+"px"; if(This.offsetWidth<=120){ clearInterval(This.time); } },30); } } } </script></body></html>
注:此项目灵感来自慕课网