完美实现js选项卡切换效果(二)


Posted in Javascript onMarch 08, 2017

本文实例为大家分享了js选项卡切换的具体代码,供大家参考,具体内容如下

通过设置定时器实现延时0.5s切换,一个重要的技巧是定义了一个that变量来存放当前指针this。

之所以不能在这直接引用this是因为setTimeout是window对象,用this的话会指向定时器,所以要在前面定义一个变量。
还要注意调用定时器前要判断是否存在准备执行的定时器。

效果如图:

完美实现js选项卡切换效果(二)

具体代码:

<!DOCTYPE html>
<html>
<head lang="en">
 <meta charset="UTF-8">
 <title>延时切换</title>
 <style type="text/css">
  *{margin: 0;padding: 0;font: normal 12px "微软雅黑";color: #000000;}
  ul{list-style-type: none;}
  a{text-decoration: none;}
  #tab-list{width: 275px;height: 190px;margin: 20px auto;}
  #ul1{border-bottom: 2px solid #8B4513;height: 32px;}
  #ul1 li{display: inline-block;width: 60px;line-height: 30px;text-align: center;
   border: 1px solid #999;border-bottom: none;margin-left: 5px;}
  #ul1 li:hover{cursor: pointer;}
  #ul1 li.active{border-top: 2px solid #8B4513;border-bottom: solid 2px #ffffff;}
  #tab-list div{border: 1px solid #7396B8;border-top: none;}
  #tab-list div li{height: 30px;line-height: 30px;text-indent: 8px;}
  .show{display: block;}.hide{display: none;}
 </style>
 <script type="text/javascript">
  window.onload=function(){
   var ul1=document.getElementById('ul1');
   var aLi=ul1.getElementsByTagName('li');
   var oDiv=document.getElementById('tab-list');
   var aDiv=oDiv.getElementsByTagName('div');
   var timer=null;
   for(var i=0;i<=aLi.length;i++){
    aLi[i].id=i;
    aLi[i].onmouseover=function(){
     var that=this;//用that这个变量来引用当前滑过的li
     //如果存在准备执行的定时器,立即清除,只能当前停留时间大于500ms时才开始执行(指鼠标快速滑过一个的那一瞬间要清除掉产生的定时器)
     if(timer){
      clearTimeout(timer);
      timer=null;
     }
     //延时半秒执行
     timer=window.setTimeout(function(){
      for(var i=0;i<aLi.length;i++){
       aLi[i].className="";
       aDiv[i].className="hide";
      }
      that.className="active";//之所以不能在这直接引用this是因为setTimeout是window对象,用this的话会指向定时器,所以要在前面定义一个变量
      aDiv[that.id].className="show";
     },500);
    }
   }
  }
 </script>
</head>
<body>
<div id="tab-list">
 <ul id="ul1">
  <li class="active">房产</li><li>家居</li><li>二手房</li>
 </ul>
 <div>
  <ul>
   <li><a href="javascript:;">275万购昌平邻铁三居 总价20万买一居</a></li>
   <li><a href="javascript:;">200万内购五环三居 140万安家东三环</a></li>
   <li><a href="javascript:;">北京首现零首付楼盘 53万购东5环50平</a></li>
   <li><a href="javascript:;">京楼盘直降5000 中信府 公园楼王现房</a></li>
  </ul>
 </div>
 <div class="hide">
  <ul>
   <li><a href="javascript:;">40平出租屋大改造 美少女的混搭小窝</a></li>
   <li><a href="javascript:;">经典清新简欧爱家 90平老房焕发新生</a></li>
   <li><a href="javascript:;">新中式的酷色温情 66平撞色活泼家居</a></li>
   <li><a href="javascript:;">瓷砖就像选好老婆 卫生间烟道的设计</a></li>
  </ul>
 </div>
 <div class="hide">
  <ul>
   <li><a href="javascript:;">通州豪华3居260万 二环稀缺2居250w甩</a></li>
   <li><a href="javascript:;">西3环通透2居290万 130万2居限量抢购</a></li>
   <li><a href="javascript:;">黄城根小学学区仅260万 121平70万抛!</a></li>
   <li><a href="javascript:;">独家别墅280万 苏州桥2居优惠价248万</a></li>
  </ul>
 </div>
</div>
</body>
</html>

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
Javascript 调试利器 Firebug使用详解六
Jul 05 Javascript
jquery $.ajax()取xml数据的小问题解决方法
Nov 20 Javascript
JavaScript学习笔记之DOM基础 2.4
Aug 14 Javascript
分享经典的JavaScript开发技巧
Nov 21 Javascript
Node.js刷新session过期时间的实现方法推荐
May 18 Javascript
AngularJS控制器controller给模型数据赋初始值的方法
Jan 04 Javascript
Angular中$state.go页面跳转并传递参数的方法
May 09 Javascript
JS设置手机验证码60s等待实现代码
Jun 14 Javascript
Bootstrap 模态框(Modal)带参数传值实例
Aug 20 Javascript
js原生日历的实例(推荐)
Oct 31 Javascript
element-ui组件中input等的change事件中传递自定义参数
May 22 Javascript
一文带你理解vue创建一个后台管理系统流程(Vue+Element)
May 18 Vue.js
微信小程序中用WebStorm使用LESS
Mar 08 #Javascript
Vue常用指令V-model用法
Mar 08 #Javascript
详解使用vue-router进行页面切换时滚动条位置与滚动监听事件
Mar 08 #Javascript
vue使用watch 观察路由变化,重新获取内容
Mar 08 #Javascript
js实现倒计时效果(小于10补零)
Mar 08 #Javascript
详解Vue监听数据变化原理
Mar 08 #Javascript
JS文件/图片从电脑里面拖拽到浏览器上传文件/图片
Mar 08 #Javascript
You might like
音乐朗读剧《MARS RED》2021年TV动画化决定!
2020/03/06 日漫
PHP的类 功能齐全的发送邮件类
2006/10/09 PHP
基于mysql的论坛(5)
2006/10/09 PHP
PHP分页函数代码(简单实用型)
2010/12/02 PHP
PHP生成条形图的方法
2014/12/10 PHP
PHP中把数据库查询结果输出为json格式简单实例
2015/04/09 PHP
Yii2.0建立公共方法简单示例
2019/01/29 PHP
PHP使用HTML5 FormData对象提交表单操作示例
2019/07/02 PHP
CSS和Javascript简单复习资料
2010/06/29 Javascript
打开新窗口关闭当前页面不弹出关闭提示js代码
2013/03/18 Javascript
浅析Javascript中“==”与“===”的区别
2014/12/23 Javascript
Bootstrap每天必学之基础排版
2015/11/20 Javascript
jQuery实现的购物车物品数量加减功能代码
2016/11/16 Javascript
微信小程序 css使用技巧总结
2017/01/09 Javascript
vue.js-div滚动条隐藏但有滚动效果的实现方法
2018/03/03 Javascript
vue.js过滤器+ajax实现事件监听及后台php数据交互实例
2018/05/22 Javascript
JS实现根据数组对象的某一属性排序操作示例
2019/01/14 Javascript
vue路由切换之淡入淡出的简单实现
2019/10/31 Javascript
python封装对象实现时间效果
2020/04/23 Python
Python连接数据库学习之DB-API详解
2017/02/07 Python
Python tkinter模块中类继承的三种方式分析
2017/08/08 Python
python实现向微信用户发送每日一句 python实现微信聊天机器人
2019/03/27 Python
python进程池实现的多进程文件夹copy器完整示例
2019/11/27 Python
Python: tkinter窗口屏幕居中,设置窗口最大,最小尺寸实例
2020/03/04 Python
在python里创建一个任务(Task)实例
2020/04/25 Python
Python基于模块Paramiko实现SSHv2协议
2020/04/28 Python
欧洲最大的化妆品连锁公司:Douglas道格拉斯
2017/05/06 全球购物
港湾网络笔试题
2014/04/19 面试题
新年联欢会主持词
2014/03/27 职场文书
党支部公开承诺书
2014/03/28 职场文书
企业文化标语口号
2014/06/09 职场文书
2014年单位法制宣传日活动总结
2014/11/01 职场文书
2015年护士长个人工作总结
2015/04/24 职场文书
毕业班工作总结
2015/08/10 职场文书
穷人该怎么创业?谨记以下几点
2019/07/11 职场文书
Go标准容器之Ring的使用说明
2021/05/05 Golang