如何用原生JS写Tab切换

简介: 1. 基本思路 ① 遍历Tab选项 ② 然后给每个Tab选项绑定点击事件 ③ 每次点击时清除所有Tab选项及Tab选项内容的样式,然后给当前Tab选项添加标记样式,给当前Tab选项添加显示样式 2.
+关注继续查看

1. 基本思路

① 遍历Tab选项
② 然后给每个Tab选项绑定点击事件
③ 每次点击时清除所有Tab选项及Tab选项内容的样式,然后给当前Tab选项添加标记样式,给当前Tab选项添加显示样式

2. 具体代码实现

<!--HTML-->
<div id="tab">
    <!--Tab选项-->
    <div class="tab-nav">
        <a href="javascript:;" class="cur">选项1</a>
        <a href="javascript:;">选项2</a>
        <a href="javascript:;">选项3</a>
    </div>
    <!--Tab选项内容-->
    <div class="tab-content">
        <div class="content content1 cur">选项内容1</div>
        <div class="content content2">选项内容2</div>
        <div class="content content3">选项内容3</div>
    </div>
</div>
/*CSS*/
#tab{ width: 300px; margin: 30px auto;}
.tab-nav{ display: flex;}
.tab-nav a{ flex: 1; line-height: 40px; border: 1px solid #000; text-align: center; text-decoration: none; color: #000;}
.tab-nav a.cur{ color: #fff; background: #000;}
.content{ display: none; width: 100%; height: 300px; color: #fff; box-sizing: border-box; padding: 10px;}
.content.cur{ display: block;}
.content1{ background: #f00; }
.content2{ background: #0f0;}
.content3{ background: #00f;}
//Javascript
window.onload = function () {
    var oTab = document.getElementById('tab');
    var aTabNav = oTab.querySelectorAll('.tab-nav a');
    var aTabContent = oTab.querySelectorAll('.tab-content .content');
    for(var i = 0; i < aTabNav.length; i++){   // 遍历Tab选项
        aTabNav[i].onclick = (function (i) {   // Tab选项绑定点击事件
            return function () {
                // 清除所有Tab选项的标记样式
                for(var j = 0; j < aTabNav.length; j++){
                    aTabNav[j].classList.remove('cur');
                }
                aTabNav[i].classList.add('cur');
                // 清除所有Tab选项内容的显示样式
                for(j = 0; j < aTabContent.length; j++){
                    aTabContent[j].classList.remove('cur');
                }
                aTabContent[i].classList.add('cur');
            }
        })(i);
    }
};

以上JS还可以继续优化,将相同功能的代码封装成函数:

window.onload = function () {
    var oTab = document.getElementById('tab');
    var aTabNav = oTab.querySelectorAll('.tab-nav a');
    var aTabContent = oTab.querySelectorAll('.tab-content .content');
    for(var i = 0; i < aTabNav.length; i++){
        aTabNav[i].onclick = (function (i) {
            return function () {
                addCurClass(aTabNav,i);
                addCurClass(aTabContent,i);
            }
        })(i);
    }
};

function addCurClass(obj,index) {
    for(var i = 0; i < obj.length; i++){
        obj[i].classList.remove('cur');
    }
    obj[index].classList.add('cur');
}

代码没有什么难度,非常基础,但是需要注意的一点是,在获取当前点击项的索引时,我们需要使用到闭包

相关推荐

教你两招用纯CSS写Tab切换
纯CSS制作单页Web应用
使用hash制作单页Web应用

相关文章
|
3月前
|
JavaScript 前端开发
使用JS来实现tab栏切换
使用JS来实现tab栏切换
39 0
|
8月前
|
JavaScript 前端开发 索引
原生js实现Tab切换(排他)功能
原生js实现Tab切换(排他)功能 在前端的面试中,一旦遇到笔试题,基本上都会有Tab切换,今天我们来说一下如何使用原生js实现Tab切换功能。如图: 在这里插入图片描述 HTML代码: &lt;div class=&quot;wrap&quot;&gt; &lt;div class=&quot;box&quot;&gt;1&lt;/div&gt; &lt;div class=&quot;box&quot;&gt;2&lt;/div&gt; &lt;div class=&quot;box&quot;&gt;3&lt;/div&gt; &lt;div class=&quot;box&quot;&gt;4&lt;/div&gt; &lt;ul&gt; &lt;li&gt;&lt;/li&gt; &lt;
原生js实现Tab切换(排他)功能
|
9月前
|
JavaScript 前端开发 CDN
哇哦,弹幕居然是这么弄出来的,一文学会如何用js制作一个弹幕效果
哇哦,弹幕居然是这么弄出来的,一文学会如何用js制作一个弹幕效果
148 0
哇哦,弹幕居然是这么弄出来的,一文学会如何用js制作一个弹幕效果
|
9月前
|
JSON JavaScript 前端开发
JS案例:如何用300行原生js代码写出高大上的购物车
JS案例:如何用300行原生js代码写出高大上的购物车
115 0
JS案例:如何用300行原生js代码写出高大上的购物车
|
11月前
|
移动开发 前端开发 JavaScript
通过JavaScript、css、H5 实现简单的tab栏的切换和复用
学习JavaScript、css、H5 实现简单的tab栏的切换和复用。
203 0
通过JavaScript、css、H5 实现简单的tab栏的切换和复用
|
JavaScript
如何用原生JS实现跑马灯效果
如何用原生JS实现跑马灯效果
89 0
如何用原生JS实现跑马灯效果
|
JavaScript 小程序
小程序在js设置data,循环点击改变tab的颜色
小程序在js设置data,循环点击改变tab的颜色
176 0
小程序在js设置data,循环点击改变tab的颜色
|
前端开发 JavaScript 索引
前端 javascript 练习题 -简易年历及tab切换
前端 javascript 练习题 -简易年历及tab切换简易年历eg1:将数组中的值输出改变样式可以直接改样式,也可以修改类名var okuang=document.getElementById("kuang");var oli=document.
731 0
|
JavaScript 前端开发 索引
相关产品
云迁移中心
推荐文章
更多