如何用原生javascript实现TAB切换

tab切换在各大主流页面有广泛的应用,今天来分享一个用原生js来实现类似京东购物边栏的TAB.

首先以下是一段边栏HTML框架代码

<body>
        <div class="wrap">
            <div id="left">
                <ul id="leftList">
                    <li>家电</li>
                    <li>手机</li>
                    <li>男装</li>
                    <li>女装</li>
                    <li>吃的</li>
                </ul>
            </div>
            <div id="right">
                <div>A</div>
                <div>B</div>
                <div>C</div>
                <div>D</div>
                <div>E</div>
            </div>
        </div>
    </body>

然后是css样式代码

<style type="text/css">
            ul {
                margin: 0;
                padding: 0;
            }
            .wrap {
                width: 1000px;
                height: 252px;
                overflow: hidden;
            }
            #left {
                width: 200px;
                height: 100%;
                background-color: red;
                border: 1px solid red;
                box-sizing: border-box;
                float: left;
            }
            #right {
                width: 800px;
                height: 100%;
                background-color: yellow;
                border: 1px solid red;
                border-left-style: none;
                float: right;
                box-sizing: border-box;
                display: none;
            }
            #leftList {
                list-style: none;
            }
            li {
                width: 100%;
                height: 50px;
                background-color: red;
                color: white;
                text-indent: 2em;
                line-height: 50px;
            }
            .current {
                background-color: white;
                color: red;
                border-right-style: none;
                border-left: 1px solid red;
            }
            #right div {
                width: 100%;
                height: 100%;
                background-color: #CCCCCC;
                text-align: center;
                font-size: 100px;
                display: none;
            }
            .show {
                display: block;
            }
        </style>

此时效果如下


此处要注意一下 因为当你的鼠标没有移到左侧时,他不会激发对应的内容,所以css样式部分#right置为none.
下面重点到了js部分,首先我们分析一下逻辑顺序,如要实现效果应该有以下几个方面

  • 鼠标移到左侧div时弹出对应的右侧内容
  • 鼠标从左侧移出到右侧后,右侧内容不消失
  • 鼠标移出左右侧后右侧内容消失

然后我们根据js语句主要的三部分(获取变量.操作.定义函数)来写js部分
首先定义变量,即

/***** 变量 *****/
        var leftDiv = document.getElementById("left");
        var rightDiv = document.getElementById("right");
        // 获取左侧列表
        var lis = document.getElementsByTagName("li");
        var divs = document.querySelectorAll("#right>div");
          // 临时变量 保存定时器(负责清除)
        var timer = null;

此处需要强调因为要有一个延时的效果,我们定义了一个定时器,即变量中的

 var timer = null;

然后进行操作

/***** 操作 *****/
        // tab切换
        for (var i = 0; i < lis.length; i++) {
            lis[i].biaoji = i;
            lis[i].onmouseover = function() {
                for (var j = 0; j < divs.length; j++) {
                    lis[j].className = "";
                    divs[j].style.display = "none";
                }
                this.className = "current";
                divs[this.biaoji].style.display = "block";
            }
        }
        leftDiv.onmouseover = function() {
            // 鼠标停留在左div时 干掉定时器
            clearInterval(timer);
            rightDiv.style.display = "block";
        }
        leftDiv.onmouseout = function() {
            // 当鼠标离开左div时 创建定时器 0.5s后清空样式
            timer = setTimeout(function() {
                rightDiv.style.display = "none";
                for (var i = 0; i < lis.length; i++) {
                    lis[i].className = "";
                }
            }, 500);
        }
        rightDiv.onmouseover = function() {
            // 利用时间差 当鼠标从左div 移入右div时
            // 先干掉定时器 保留刚才的效果
            clearTimeout(timer);
            this.style.display = "block";
        }
        rightDiv.onmouseout = function() {
            // 当鼠标从右侧div离开时 清除样式
            timer = setTimeout(function() {
                rightDiv.style.display = "none";
                for (var i = 0; i < lis.length; i++) {
                    lis[i].className = "";
                }
            }, 500);
        }

如果要实现更多个对象的处理为了代码简洁我们可以把其中相同的部分提出来封装成函数使用时再调用就可以了.
实现效果如下


最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • tab切换在各大主流页面有广泛的应用,今天来分享一个用原生js来实现类似京东购物边栏的TAB. 首先以下是一段边栏...
    lucifrom_long阅读 352评论 0 1
  • Android 自定义View的各种姿势1 Activity的显示之ViewRootImpl详解 Activity...
    passiontim阅读 174,522评论 25 709
  • 圣诞节如愿听了人生第一场刘若英的演唱会。听到某首歌的时候,忍不住哭了,而且是泪流满面。是的,就是那首刘若英已经唱吐...
    陳2妹阅读 145评论 0 0
  • 来自遥远的问候, 飘向远方的你, 我在黄土高原的一偶, 默默的祝福着远方的你, 你可曾听到,我亲爱的你。 你可曾记...
    就爱嗑瓜子阅读 145评论 1 0