用JS写一个选项卡

用JS写一个选项卡

<!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>
        #div1 button{width: 100px;height: 30px;background-color: gray;color: white;font-size: 10px;}
        #div1 .active{background-color: orange;color: blue;}
        #div1 div{width: 340px;height: 300px;border: 1px solid black;display: none;}
    </style>
    <script>
        window.onload = function(){
            var oDiv1=document.getElementById("div1");
            var aBtns=oDiv1.getElementsByTagName("button");
            var aDivs=oDiv1.getElementsByTagName("div");

            //给每一个按钮添加点击
            for(var i = 0;i<aBtns.length;i++)
            {
                aBtns[i].index = i;
                aBtns[i].onclick = function(){
                  for(var j = 0;j<aBtns.length;j++)
                {
                    aBtns[j].className = '';
                    aDivs[j].style.display = 'none';
                }
                aDivs[this.index].style.display = 'block';
                this.className = 'active';  
                }
            }
        }
    </script>
</head>
<body>
    <div id="div1">
       <button class="active">HTML</button> 
       <button>Python</button>
       <button>Java</button>
       <div style="display: block;">1111</div>
       <div>222</div>
       <div>333</div>
    </div>
</body>
</html>

实现效果:

选项卡

好的,以下是一个基本的选项卡切换的实现: HTML代码: ```html <div class="tab"> <button class="tablinks" onclick="openTab(event, 'tab1')">选项卡1</button> <button class="tablinks" onclick="openTab(event, 'tab2')">选项卡2</button> <button class="tablinks" onclick="openTab(event, 'tab3')">选项卡3</button> </div> <div id="tab1" class="tabcontent"> <h3>选项卡1</h3> <p>这是选项卡1的内容。</p> </div> <div id="tab2" class="tabcontent"> <h3>选项卡2</h3> <p>这是选项卡2的内容。</p> </div> <div id="tab3" class="tabcontent"> <h3>选项卡3</h3> <p>这是选项卡3的内容。</p> </div> ``` CSS代码: ```css .tab { overflow: hidden; border: 1px solid #ccc; background-color: #f1f1f1; } .tab button { background-color: inherit; float: left; border: none; outline: none; cursor: pointer; padding: 14px 16px; transition: 0.3s; } .tab button:hover { background-color: #ddd; } .tab button.active { background-color: #ccc; } .tabcontent { display: none; padding: 6px 12px; border: 1px solid #ccc; border-top: none; } ``` JavaScript代码: ```javascript function openTab(evt, tabName) { var i, tabcontent, tablinks; tabcontent = document.getElementsByClassName("tabcontent"); for (i = 0; i < tabcontent.length; i++) { tabcontent[i].style.display = "none"; } tablinks = document.getElementsByClassName("tablinks"); for (i = 0; i < tablinks.length; i++) { tablinks[i].className = tablinks[i].className.replace(" active", ""); } document.getElementById(tabName).style.display = "block"; evt.currentTarget.className += " active"; } ``` 在这个示例中,我们首先定义了一个包含选项卡按钮和内容的HTML结构。然后,我们使用CSS样式来设置选项卡的外观。最后,我们使用JavaScript来实现选项卡切换的逻辑。具体来说,当用户点击选项卡按钮时,我们会隐藏所有选项卡内容,并将所有选项卡按钮的类名设置为非活动状态。然后,我们显示当前选项卡的内容,并将其对应的按钮类名设置为活动状态。这样,用户就可以通过点击不同的选项卡按钮来切换选项卡内容了。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

东方求败、

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值