JavaScript实现tab栏切换的效果

 更新时间:2021年09月30日 14:20:15   作者:qq_39111074  
这篇文章主要为大家详细介绍了JavaScript实现tab栏切换的效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

tab栏:点击不同的标签,显示不同的内容,被点击的标签样式发生改变(突出选中的是哪一个)

实现思路:

1、将tab栏分为上下两部分,上面是导航列表,下面是各部分对应的内容。把标签和内容都写出来,内容按照标签顺序依次顺着写,给标签都添加自定义属性- - -index,属性值从0开始,依次增加1

2、首先实现上面的效果,点击后样式切换,被点击的字体颜色、背景颜色改变等:

①css定义一个类eg:current,里面定义改变后的样式,先给第一个标签写一个该类名,其他的不写类名,
②js获取所有标签元素对象,- - -for循环- - -遍历给每个标签绑定- - -onclick点击事件
③点击事件里面使用排他算法- - -for循环- - -将所有标签设置类名为空- - -className = ‘' ,然后当前被点击的标签设置上面定义的特殊类名- - -this.className = ‘current';

3、实现下面,根据点击的标签,出现不同的内容:

①css将第一个标签对应内容显示,其他的都隐藏起来:

.box-tb .item:nth-child(n+2) {
display: none;
}

②获取内容的全部元素对象,获取标签的index值,在点击事件里再添加一个排他思想代码- - -for循环- - -遍历内容的元素对象,将所有内容设置隐藏- - -items[i].style.display = ‘none';然后根据被点击的标签,将对应的内容显示- - -items[index].style.display = ‘block';

代码示例:

<!DOCTYPE html>
<html lang="en">

<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>tab栏切换</title>
    <style>
        * {
            margin: 0;
            padding: 0;
        }
        
        li {
            list-style: none;
        }
        
        .box {
            width: 600px;
            margin: 100px auto;
        }
        
        .box-th {
            overflow: hidden;
            width: 100%;
            background-color: #88ace6;
        }
        
        .box-th ul li {
            float: left;
            width: 90px;
            height: 20px;
            margin-right: 10px;
            padding: 5px;
            text-align: center;
        }
        
        .current {
            color: #fff;
            background-color: green;
        }
        
        .box-tb {
            margin-top: 20px;
        }
        
        .box-tb .item:nth-child(n+2) {
            display: none;
        }
    </style>
</head>

<body>
    <div class="box">
        <div class="box-th">
            <ul>
                <li data-index="0" class="current">春</li>
                <li data-index="1">夏</li>
                <li data-index="2">秋</li>
                <li data-index="3">冬</li>
            </ul>
        </div>
        <div class="box-tb">
            <div class="item">春季排四季之首,新的轮回从此开启。春,代表着温暖、生长,植物发芽,风和日暖,鸟语花香。这季节的气温、日照、降雨,处于一年中的转折点,趋于上升或增多。春季,阴阳之气开始转变,万物随阳气上升而萌牙生长,春季是万物生长、春耕播种的季节,所谓“一年之计在于春”。 春季起始—结束: 依据天象变化划分:传统上是以“立春”(斗指寅,太阳达黄经315°时)作为春季的起点,至“立夏”结束。 依据气温变化划分:近代采用学者张宝堃的“候平均气温”划分,以候平均温度(连续5天气温的平均)从10℃以下稳定升到10℃以上时作为春季开始,至候平均温度22℃以上(入夏)时结束。
            </div>
            <div class="item">夏季万物至此皆盛,是农作物进入旺季生长的一个季节。温度升高,天气炎热,狂风暴雨频发,万物盛长。夏季是风暴最多的季节,常伴随着大风、暴雨。北半球夏季,大陆受热气压上升形成低气压,海洋恒温温度相对较低形成高气压,根据环流,夏季吹的是东南风。夏季北半球各地的白昼时间全年最长。 夏季起始—结束: 依据天象变化划分:以“立夏”(斗指东南,太阳达黄经45°)作为夏季的起点,至“立秋”结束。 依据气温变化划分:以候平均温度稳定升到22℃以上时作为夏季开始,至候平均温度22℃以下时结束。
            </div>
            <div class="item">秋季是收获季节,意味着万物开始从繁茂成长趋向萧索成熟。秋季的前两个节气立秋、处暑,还是酷热天气,因太阳所带来的热力未减弱,所谓“热在三伏”,三伏天出现在小暑与处暑之间,是一年中气温最高且又潮湿、闷热的日子。造成三伏天湿度高原因是,三伏天吹东南风,而东南方是太平洋和印度洋,空气潮湿,风的潮湿造成了三伏天湿度大;到了深秋之后则相反,吹西北风,而西北方是干燥的内陆,干燥的西北风造成深秋之后气候干燥。秋季前两个节气的气候特征为潮湿、闷热,秋季真正凉爽一般要到白露节气之后,自白露起渐渐趋向凉爽、干燥。随着进入深秋,气候由热转凉,万物随寒气增长,逐渐萧落,这是热与冷交替的季节。秋季最明显的变化草木的叶子从繁茂的绿色到发黄,并开始落叶庄稼则开始成熟。
                [1] 秋季起始—结束: 依据天象变化划分:以“立秋”(斗指西南,太阳达黄经135°)作为秋季的起点,至“立冬”结束。 依据气温变化划分:以候平均温度从22℃以上稳定降到22℃以下作为秋季开始,至候平均温度降到10℃以下时结束。
            </div>
            <div class="item">冬季,阴阳转变,万物由收到藏,植物生气闭蓄。进入立冬后意味着秋季少雨干燥气候渐过去,转为阴雨寒冻的冬季气候特征。北半球的太阳高度小,白昼时间短。所谓“热在三伏”,冷在三九”,冬至为"一九天",冬至之前还不算很冷,冬至过后强冷空气南下频繁,并越过了南岭,气温骤降,天气寒冷。冬季真正寒冷,是在冬至后。 冬季起始—结束: 依据天象变化划分:以“立冬”(斗指西北,太阳达黄经225°)作为冬季的起点,至下一“立春”结束。 依据气温变化划分:以候平均温度稳定降到10℃以下为冬季的开始,至候平均温度10℃以上时结束。
            </div>
        </div>
    </div>

    <script>
        var list = document.querySelector('.box-th').querySelectorAll('li');
        var items = document.querySelector('.box-tb').querySelectorAll('.item');
        for (var i = 0; i < list.length; i++) {
            list[i].onclick = function() {
                // 导航栏样式切换,排他算法
                for (var i = 0; i < list.length; i++) {
                    list[i].className = '';
                }
                this.className = 'current';

                // 下面展示内容切换,排他算法
                var index = this.getAttribute('data-index');
                for (var i = 0; i < items.length; i++) {
                    items[i].style.display = 'none';
                }
                items[index].style.display = 'block';
            }
        }
    </script>
</body>

</html>

页面效果:

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

相关文章

  • JavaScript实现多栏目切换效果

    JavaScript实现多栏目切换效果

    在网站开发中尤其是新闻类网站,经常遇到多栏目切换的设计,这种效果有很多种实现效果,现在记录一种很简单的写法
    2016-12-12
  • uniapp组件之tab选项卡滑动切换功能实现

    uniapp组件之tab选项卡滑动切换功能实现

    这篇文章主要介绍了uniapp组件之tab选项卡滑动切换功能实现,本文结合实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧
    2023-01-01
  • 基于JavaScript实现瀑布流效果

    基于JavaScript实现瀑布流效果

    这篇文章主要为大家详细介绍了基于JavaScript实现瀑布流效果,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-03-03
  • JS获取img图片原始尺寸高度与宽度的七种方式

    JS获取img图片原始尺寸高度与宽度的七种方式

    近期做项目由于每张图片加载的时候比例大小都不一样,加载图片时大部分图片会变形,导致图片展示效果非常差,所以我们可以获取图片的原始宽高,然后以等比例展示,效果会非常好,这篇文章主要给大家介绍了关于JS获取img图片原始尺寸高度与宽度的七种方式,需要的朋友可以参考下
    2022-11-11
  • 微信小程序实现音频文件播放进度的实例代码

    微信小程序实现音频文件播放进度的实例代码

    这篇文章主要介绍了微信小程序实现音频文件播放进度的实例代码,代码包括对进度条的实现及进度条的滑动,对大家的工作或学习具有一定的参考借鉴价值,需要的朋友可以参考下
    2020-03-03
  • JavaScript将坐标字符串转为数组的项目实践

    JavaScript将坐标字符串转为数组的项目实践

    本文主要介绍了JavaScript将坐标字符串转为数组的项目实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2024-01-01
  • pdfmake生成pdf的使用方法

    pdfmake生成pdf的使用方法

    本文介绍了如何使用pdfmake第三方库在项目中根据模板生成PDF文件,文中还提到了常用的配置,如页眉和页脚效果,对pdfmake pdf使用方法感兴趣的朋友一起看看吧
    2024-09-09
  • JavaScript函数封装的示例详解

    JavaScript函数封装的示例详解

    这篇文章主要通过动画的示例来为大家详细介绍一下JavaScript的函数封装,文中的示例代码讲解详细,感兴趣的小伙伴可以学习一下
    2022-03-03
  • JavaScript中call、apply、bind实现原理详解

    JavaScript中call、apply、bind实现原理详解

    其实在很多文章都会写call,apply,bind,但个人觉着如果不弄懂原理,是很难理解透的,所以这篇文章主要介绍了JavaScript中call、apply、bind实现原理的相关资料,需要的朋友可以参考下
    2021-06-06
  • 微信小程序新增的拖动组件movable-view使用教程

    微信小程序新增的拖动组件movable-view使用教程

    这篇文章主要给大家介绍了微信小程序最近新增的拖动组件movable-view的简单使用教程,文中介绍的非常详细,对大家具有一定的参考学习价值,需要的朋友们下面来一起看看吧。
    2017-05-05

最新评论