…">
当前位置:首页 > JavaScript

js 实现tabs

2026-03-02 08:34:59JavaScript

JavaScript 实现 Tabs 功能

实现 Tabs(标签页)功能可以通过纯 JavaScript 完成,以下是核心实现步骤:

HTML 结构

<div class="tabs">
  <div class="tab-header">
    <button class="tab-btn active" data-tab="tab1">Tab 1</button>
    <button class="tab-btn" data-tab="tab2">Tab 2</button>
    <button class="tab-btn" data-tab="tab3">Tab 3</button>
  </div>
  <div class="tab-content">
    <div class="tab-panel active" id="tab1">Content 1</div>
    <div class="tab-panel" id="tab2">Content 2</div>
    <div class="tab-panel" id="tab3">Content 3</div>
  </div>
</div>

CSS 样式

.tab-btn {
  padding: 10px 20px;
  background: #eee;
  border: none;
  cursor: pointer;
}
.tab-btn.active {
  background: #ddd;
}
.tab-panel {
  display: none;
  padding: 20px;
  border: 1px solid #ddd;
}
.tab-panel.active {
  display: block;
}

JavaScript 逻辑

document.querySelectorAll('.tab-btn').forEach(btn => {
  btn.addEventListener('click', () => {
    // 移除所有按钮和面板的active类
    document.querySelectorAll('.tab-btn').forEach(b => b.classList.remove('active'));
    document.querySelectorAll('.tab-panel').forEach(p => p.classList.remove('active'));

    // 为当前按钮和对应面板添加active类
    btn.classList.add('active');
    const tabId = btn.getAttribute('data-tab');
    document.getElementById(tabId).classList.add('active');
  });
});

增强版实现(支持动态添加)

如果需要支持动态添加标签页,可以使用事件委托:

document.querySelector('.tab-header').addEventListener('click', (e) => {
  if (e.target.classList.contains('tab-btn')) {
    const tabId = e.target.getAttribute('data-tab');

    // 更新按钮状态
    document.querySelectorAll('.tab-btn').forEach(b => 
      b.classList.toggle('active', b === e.target)
    );

    // 更新内容面板
    document.querySelectorAll('.tab-panel').forEach(p => 
      p.classList.toggle('active', p.id === tabId)
    );
  }
});

注意事项

  • 确保 data-tab 属性值与对应面板的 id 完全匹配
  • 初始状态通过 active 类控制默认显示的标签页
  • 可以通过 CSS 过渡效果增强切换动画
  • 移动端适配可能需要调整点击区域大小

框架实现示例(Vue)

如果使用现代前端框架,实现会更简洁:

js 实现tabs

<!-- Vue 示例 -->
<div class="tabs">
  <div class="tab-header">
    <button 
      v-for="(tab, index) in tabs" 
      :key="index"
      @click="activeTab = index"
      :class="{ active: activeTab === index }"
    >
      {{ tab.title }}
    </button>
  </div>
  <div class="tab-content">
    <div 
      v-for="(tab, index) in tabs"
      :key="index"
      class="tab-panel"
      :class="{ active: activeTab === index }"
    >
      {{ tab.content }}
    </div>
  </div>
</div>
new Vue({
  data: {
    activeTab: 0,
    tabs: [
      { title: 'Tab 1', content: 'Content 1' },
      { title: 'Tab 2', content: 'Content 2' },
      { title: 'Tab 3', content: 'Content 3' }
    ]
  }
});

标签: jstabs
分享给朋友:

相关文章

js实现抽奖

js实现抽奖

实现抽奖功能的基本思路 抽奖功能的核心是随机选择奖项并展示结果。可以通过数组存储奖项,利用随机数生成索引,最后通过动画增强用户体验。 准备奖项数据 定义一个数组存储奖项信息,每个奖项可以包含名称、图…

js实现投球

js实现投球

实现投球动画的基本思路 使用JavaScript和CSS动画结合的方式模拟投球效果。核心是通过改变元素的位置、旋转和缩放属性,配合定时器或CSS过渡实现平滑动画。 创建基础HTML结构 <…

链表实现js

链表实现js

链表的基本概念 链表是一种线性数据结构,由一系列节点组成,每个节点包含数据和一个指向下一个节点的指针(单向链表)或两个指针(双向链表)。与数组不同,链表在内存中非连续存储,插入和删除操作更高效,但随机…

js实现 功能

js实现 功能

在 JavaScript 中实现功能通常涉及多个关键步骤,具体取决于功能需求。以下是常见功能的实现方法和示例: 基本功能实现 使用函数封装逻辑是最直接的方式。例如,实现一个计算两数之和的函数: f…

js 实现跳转

js 实现跳转

使用 window.location.href 进行跳转 通过修改 window.location.href 可以跳转到指定 URL,浏览器会加载新页面: window.location.hre…

js实现左右滑动

js实现左右滑动

实现左右滑动的 JavaScript 方法 监听触摸事件 通过 touchstart、touchmove 和 touchend 事件来检测用户的手势操作。记录触摸的起始位置和移动距离,判断滑动方向。…