css梯形tab

效果:

代码:

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Tab 示例</title>
    <style>
        /* 定义 CSS 变量 */
        :root {
            --tab-width: 200px;
            --tab-height: 50px;
            --tab-radius: 10px;
            --tab-bg: #EFF6FF;
            --tab-active-bg: gold;
            --tab-corner-size: 10px;
        }

        /* 基础样式 */
        .box {
            padding: 50px 300px;
            text-align: center;
            display: flex;
        }

        /* Tab 通用样式 */
        .tab {
            width: var(--tab-width);
            height: var(--tab-height);
            background-color: var(--tab-bg);
            position: relative;
            border-radius: var(--tab-radius) var(--tab-radius) 0 0;
            transform-origin: center bottom;
            transform: perspective(10px) rotateX(10deg);
            cursor: pointer; /* 添加鼠标指针样式 */
        }

        /* Tab 伪元素样式 */
        .tab::before,
        .tab::after {
            content: "";
            position: absolute;
            bottom: 0;
            width: var(--tab-corner-size);
            height: var(--tab-corner-size);
            background: var(--tab-bg);
        }

        .tab::before {
            left: calc(-1 * var(--tab-corner-size));
            background: radial-gradient(circle at 0 0, transparent var(--tab-corner-size), var(--tab-bg) var(--tab-corner-size));
        }

        .tab::after {
            right: calc(-1 * var(--tab-corner-size));
            background: radial-gradient(circle at var(--tab-corner-size) 0, transparent var(--tab-corner-size), var(--tab-bg) var(--tab-corner-size));
        }

        /* 第二个 Tab 的特殊样式 */
        .tab2 {
            top: -26px;
            margin-left: -50px;
            transform: perspective(10px) rotateX(170deg);
        }

        /* 激活状态的 Tab 样式 */
        .active {
            background-color: var(--tab-active-bg);
        }

        .active::before {
            background: radial-gradient(circle at 0 0, transparent var(--tab-corner-size), var(--tab-active-bg) var(--tab-corner-size));
        }

        .active::after {
            background: radial-gradient(circle at var(--tab-corner-size) 0, transparent var(--tab-corner-size), var(--tab-active-bg) var(--tab-corner-size));
        }
    </style>
</head>
<body>
    <div class="box">
        <div class="tab tab1 active"></div>
        <div class="tab tab2"></div>
    </div>

    <script>
        const tabs = document.querySelectorAll(".tab");
        tabs.forEach((tab) => {
            tab.addEventListener("click", () => {
                tabs.forEach((t) => t.classList.remove("active"));
                tab.classList.add("active");
            });
        });
    </script>
</body>
</html>
相关推荐
wenzhangli718 分钟前
Ooder A2UI 核心架构深度解析:WEB 拦截层的设计与实现
前端·架构
前端百草阁42 分钟前
【前端性能优化全链路指南】从开发编写到构建运行的多维度实践
前端·性能优化
女生也可以敲代码1 小时前
AI时代下的50道前端开发面试题:从基础到大模型应用
前端·面试
ZhengEnCi1 小时前
M5-markconv自定义CSS样式指南 📝
前端·css·python
IT_陈寒1 小时前
SpringBoot自动配置的坑差点让我加班到天亮
前端·人工智能·后端
xingpanvip1 小时前
星盘接口开发文档:星相日历接口指南
android·开发语言·前端·css·php·lua
@PHARAOH2 小时前
WHAT - GitLens supercharged 插件
前端
TT模板2 小时前
苹果cms整合西瓜播放器XGplayer插件支持跳过片头尾
前端·html5
Wect3 小时前
React 性能优化精讲
前端·react.js·性能优化
追风筝的人er3 小时前
SpringBoot+Vue3 企业考勤如何处理法定假期?节假日方案、调休补班与工作日判断链路拆解
前端·vue.js·后端