(1)功能描述:
鼠标经过标题显示对应模块
(2)实现代码:
HTML:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml" xml:lang="en"> <head> <meta http-equiv="Content-Type" content="text/html;charset=UTF-8"> <title>Document</title> </head> <body> <div id="box"> <ul id="tab"> <li class="active">第一课</li> <li>第二课</li> <li>第三课</li> </ul> <div id="content"> <ul style="display:block;"> <li>网页特效原理分析</li> <li>响应用户操作</li> <li>提示框效果</li> <li>事件驱动</li> <li>元素属性操作</li> <li>动手编写第一个JS特效</li> <li>引入函数</li> <li>网页换肤效果</li> <li>事件驱动</li> <li>展开/收缩播放列表效果</li> </ul> <ul> <li>改变网页背景颜色</li> <li>函数传参</li> <li>高重用性函数的编写</li> <li>126邮箱全选效果</li> <li>循环及遍历操作</li> <li>调试器的简单使用</li> <li>典型循环的构成</li> <li>for循环配合if判断</li> <li>className的使用</li> <li>innerHTML的使用</li> <li>戛纳印象效果</li> <li>数组</li> <li>字符串连接</li> </ul> <ul> <li>JavaScript组成:ECMAScript、DOM、BOM,JavaScript兼容性来源</li> <li>JavaScript出现的位置、优缺点</li> <li>变量、类型、typeof、数据类型转换、变量作用域</li> <li>闭包:什么是闭包、简单应用、闭包缺点</li> <li>运算符:算术、赋值、关系、逻辑、其他运算符</li> <li>程序流程控制:判断、循环、跳出</li> <li>命名规范:命名规范及必要性、匈牙利命名法</li> <li>函数详解:函数构成、调用、事件、传参数、可变参、返回值</li> <li>定时器的使用:setInterval、setTimeout</li> <li>定时器应用:站长站导航效果</li> <li>定时器应用:自动播放的选项卡</li> <li>定时器应用:数码时钟</li> <li>程序调试方法</li> </ul> </div> </div> </body> </html>
CSS:
<style> *{margin: 0px;padding: 0px;} body{padding: 100px;font-size: 13px;} #box{width: 500px;} #box #tab{border: 1px solid black;overflow: hidden;background-color: black;} #box #tab li{float: left;height: 30px;line-height: 30px;list-style: none;width: 80px;text-align: center;color: #fff;cursor: pointer;} #box #tab li.active{background-color: #eee;color: #000;} #box #content{} #box #content ul{display: none;border: 1px solid black;border-top: none;padding:8px 0 8px 25px;} #box #content ul li{height: 28px;line-height: 28px;} </style>
JS:
<script> window.onload=function(){ var aTab = document.getElementById('tab').getElementsByTagName('li'); var aBox = document.getElementById('content').getElementsByTagName('ul'); for(var i=0;i<aTab.length;i++){ aTab[i].index=i; aTab[i].onmouseover=function(){ for(var j=0;j<aTab.length;j++){ aTab[j].className=''; aBox[j].style.display='none'; } this.className='active'; aBox[this.index].style.display='block'; } } } </script>
(3)效果图如下所示:
(4)注意事项:
index this 是整个js实现要注意的地方,index为自定义属性,表示第几个标签,从而可以对应的显示第几个内容。this在这里是标题。