js自定义Tab选项卡效果

前端之家收集整理的这篇文章主要介绍了js自定义Tab选项卡效果前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

自定义Tab选项卡,具体内容如下

规范HTML格式

在设计选项卡之前,先规范一下HTML的格式。

  • 面板2
  • 如上述代码所示,这里并没有声明太多类名,只有容器样式类m-tab-Container和激活样式类active两个。其他元素的样式都是通过这两个类一层一层往下找然后进行设置。

    设计CSS样式

    ul,.m-tab-container>div{ padding:0; margin:0; } .m-tab-container>ul{ flex:0; min-width:50px; } .m-tab-container>div{ position:relative; flex:1; border:1px solid #ddd; background-color:#fff; padding:10px; z-index:2; } .m-tab-container>ul>li{ display:block; margin:0 0 5px 0; } .m-tab-container>ul>li>a{ position:relative; line-height:40px; display:block; width:100%; text-align:center; text-decoration:none; background-color:#fff; border: 1px solid #ddd; border-right:0; z-index:1; } .m-tab-container>ul>li>a,.m-tab-container>ul>li.active>a:hover,.m-tab-container>ul>li.active>a:link,.m-tab-container>ul>li.active>a:visited,.m-tab-container>ul>li.active>a:active{ color:#000; } .m-tab-container>ul>li.active>a{ z-index:3; } .m-tab-container>div>div{ display:none; } .m-tab-container>div>div.active{ display:block; } .m-tab-container>ul>li.active,.m-tab-container>ul>li.active>a{ cursor: default; }

    li里面的a标签display设置成block后,长度超过了li,能够覆盖掉内容面板的边框形成空缺(经过测试,li设置边框之后和内容面板的div边框相距不足1px,也可以使用margin让li和div重叠,然后用li覆盖掉div的边框)。

    绑定JS代码

    页面加载后的工作 $("div.m-tab-container li a").on("click",function(e) { e.preventDefault(); // 可以在这里判断被点击的a标签是否已经激活 $(".active").removeClass("active"); $(this).closest("li").addClass("active") $($(this).attr("href")).addClass("active"); }) })(jQuery);

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

    原文链接:https://www.f2er.com/js/38841.html

    猜你在找的JavaScript相关文章