案例:选项卡

选项卡
需求:
1.选项卡由英雄联盟、DOTA、风暴英雄、300英雄四块组成;
2.未选择时,默认选中第一个标签页;
3.选择某一选项后,下方跳出对应游戏的相关介绍内容。
实现原理:
将四块详情页定位重叠并隐藏,一开始只给第一个标题与对应的详情页添加class实现2
通过移除所有激活类名取消激活状态再给点击元素添加激活类名实现3

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        *{
            margin: 0;
            padding: 0;
        }
        .topic{
            width: 100%;
            list-style: none;
            display: flex;
            margin-bottom: 15px;
        }
        .topic li{
            flex: 1;
            height: 50px;
            line-height: 50px;
            text-align: center;
            font-size: 20px;
            cursor: pointer;
        }
        .detail li{
            height: 200px;
            width: 100%;
            display: none;
        }
        .detail li img{
            height:100px;
            width: 150px;
        }
        .detail li span{
            float:right;
            width: 100%;
            font-size: 16px;
            line-height: 20px;
            text-align: left;
            color: rgb(36, 35, 35);
        }
        .topic .active{
            border-bottom:1px solid orange;;
            color: orange;
        }
        .detail .active{
            display: flex;
        }

    </style>
</head>
<body>
    <ul class="topic">
        <li class="active">英雄联盟</li>
        <li>DOTA</li>
        <li>风暴英雄</li>
        <li>300英雄</li>
    </ul>
    <ul class="detail">
        <li class="active">
            <img src="./JS学习/img/3801213fb80e7becf4dcebf22d2eb9389b506b9b.png">
            <span>《300英雄》是由上海跳跃网络科技有限公司自主研发,深圳中青宝互动网络股份有限公司运营的一款类DOTA网游。游戏以7v7组队对抗玩法为主,提供永恒战场和永恒竞技场两种经典模式任由玩家选择,并创新性地加入勇者斗恶龙、克隆战争等多种休闲娱乐玩法。</span>
        </li>
        <li>
            <img src="./JS学习/img/78310a55b319ebc4a5919fa98c26cffc1e171610.png">
            <span>
                《风暴英雄》 是由暴雪娱乐公司开发的一款运行在Windows和Mac OS上的在线多人竞技PC游戏。
                游戏中的英雄角色主要来自于暴雪四大经典游戏系列:《魔兽世界》、《暗黑破坏神》、《星际争霸》和《守望先锋》。它是一款道具收费的游戏,与《星际争霸Ⅱ》基于同一引擎开发。
                 2022年11月17日,上海网之易网络科技发展有限公司发布公告称,由于公司与合作方暴雪娱乐的协议期限即将届满,在中国大陆地区由公司所运营的《风暴英雄》,将于2023年1月24日0时终止运营。
            </span>
        </li>
        <li>
            <img src="./JS学习/img/4e4a20a4462309f73a781082780e0cf3d7cad60f.png">
            <span>
                《DotA》(Defense of the Ancients),可以译作守护古树、守护遗迹、远古遗迹守卫, 是由暴雪公司出品即时战略游戏《魔兽争霸3》的一款多人即时对战、自定义地图,可支持10个人同时连线游戏,是暴雪公司官方认可的魔兽争霸的RPG地图。
                最早的DOTA地图则在混乱之治时代就出现了,一位叫做Eul(Euls)的玩家制作了第一张DOTA地图《RoC DOTA》,其中两队都只有总共5个英雄,非常简单 [1]  。
                Eul(Euls)退出之后有位玩家Steve Guinsoo整合了很多个英雄制作了DotA Allstars。在2005年,6.01版发布不久,IceFrog同Neichus对地图进行了多次修正和更新。之后Neichus退出,IceFrog成为主要的地图程序员,负责包括游戏的执行和平衡的测试在内的任何工作。随着6系列版本不断被发布,bug的修正,新的英雄和新增加的法术不断被引入《DotA》。
                最终游戏分为两个阵营,玩家需要操作英雄,通过摧毁对方遗迹建筑来获取最终胜利。这种多人在线竞技模式后来被称为“Dota类游戏“,对之后的许多游戏产生了深远的影响。
            </span>
        </li>
        <li>
            <img src="./JS学习/img/f703738da9773912b31b79f4de529118367adab44458.png">
            <span>
                《英雄联盟》(League of Legends,简称LOL)是由美国拳头游戏(Riot Games)开发、中国内地由腾讯游戏代理运营的英雄对战MOBA竞技网游。游戏里拥有数百个个性英雄,并拥有排位系统、符文系统等特色系统。
                《英雄联盟》致力于推动全球电子竞技的发展,除了联动各赛区发展职业联赛、打造电竞体系之外,每年还会举办“英雄联盟季中冠军赛”、“英雄联盟全球总决赛”、“英雄联盟全明星赛”三大世界级赛事,形成了自己独有的电子竞技文化 [1]2018年5月14日,《英雄联盟》加入“亚洲运动会”,成为表演项目之一 [85]  。2021年11月5日,《英雄联盟》入选为第19届“亚洲运动会”电竞比赛项目,这是电竞首次成为亚运会的正式竞赛项目,向全世界展现电竞运动的魅力,项目所获得的奖牌将计入国家奖牌榜 [99]2019年9月17日,拳头游戏值《英雄联盟》十周年之际发布了其全新的LOGO,并公布每一天全世界都有超过八百万玩家同时在线,这意味着英雄联盟依然是全球玩家数最大的电脑游戏 [84]2023年1月9日,据《英雄联盟》开发人员消息,《英雄联盟》将在 13.2 版本开始测试新的“15 投”规则,4/5 赞成票即可通过;《英雄联盟》 13.1 版本预计将在 2023113 日上线,届时将推出《英雄联盟》无限乱斗模式。13.2 版预计将在 126 日上线。
            </span>
        </li>
    </ul>
    <script>
        var topic=document.querySelectorAll(".topic li")
        var detail=document.querySelectorAll(".detail li")
        //给每li添加自定义属性标识,并且设置标题的点击事件
        for(var i=0;i<topic.length;i++){
            topic[i].dataset.index=i
            topic[i].onclick=handler
        }
        function handler(){
           //辨识点击哪个标题
            var index=this.dataset.index
            //移除激活类名
            for(var j=0;j<topic.length;j++){
               topic[j].classList.remove("active")
               detail[j].classList.remove("active")
            }
            //添加激活类名
            topic[index].classList.add("active")
            detail[index].classList.add("active")
        }
    </script>
</body>
</html>

1673507320937

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值