24eb1fa0创建于 2025年8月12日历史提交
<template>
  <header class="header">
    <div class="container header-container">
      <router-link class="header-logo" to="/">
        <img src="/images/logo.svg" alt="SilkUI Logo" />
        <span>SilkUI</span>
      </router-link>
      <nav class="header-nav">
        <router-link class="header-nav-item" to="/guide/introduction">指南</router-link>
        <router-link class="header-nav-item" to="/components/button">组件</router-link>
        <a class="header-nav-item" href="https://github.com/yourusername/silkui" target="_blank">GitHub</a>
      </nav>
      <div class="header-mobile-nav-btn" @click="toggleMobileNav">
        <span></span>
        <span></span>
        <span></span>
      </div>
    </div>
    <div class="mobile-nav" :class="{ 'mobile-nav-active': mobileNavActive }">
      <router-link class="mobile-nav-item" to="/guide/introduction" @click="closeMobileNav">指南</router-link>
      <router-link class="mobile-nav-item" to="/components/button" @click="closeMobileNav">组件</router-link>
      <a class="mobile-nav-item" href="https://github.com/yourusername/silkui" target="_blank">GitHub</a>
    </div>
  </header>
</template>

<script setup>
import { ref } from 'vue';

const mobileNavActive = ref(false);

const toggleMobileNav = () => {
  mobileNavActive.value = !mobileNavActive.value;
};

const closeMobileNav = () => {
  mobileNavActive.value = false;
};
</script>

<style lang="scss" scoped>
.header {
  position: fixed;
  top: 0;
  left: 0;
  right: 0;
  height: var(--header-height);
  background-color: #fff;
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.1);
  z-index: 100;
}

.header-container {
  display: flex;
  align-items: center;
  justify-content: space-between;
  height: 100%;
}

.header-logo {
  display: flex;
  align-items: center;
  font-size: 20px;
  font-weight: 600;
  color: var(--text-color);

  img {
    height: 32px;
    margin-right: 8px;
  }
}

.header-nav {
  display: flex;
  align-items: center;
}

.header-nav-item {
  margin-left: 24px;
  font-size: 15px;
  color: var(--text-color);
  transition: color 0.3s;

  &:hover, &.router-link-active {
    color: var(--primary-color);
  }
}

.header-mobile-nav-btn {
  display: none;
  flex-direction: column;
  justify-content: space-between;
  width: 24px;
  height: 20px;
  cursor: pointer;

  span {
    display: block;
    width: 100%;
    height: 2px;
    background-color: var(--text-color);
    transition: all 0.3s;
  }
}

.mobile-nav {
  display: none;
  position: fixed;
  top: var(--header-height);
  left: 0;
  right: 0;
  background-color: #fff;
  box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1);
  padding: 16px 0;
  transform: translateY(-100%);
  opacity: 0;
  transition: all 0.3s;
  z-index: 99;

  &.mobile-nav-active {
    transform: translateY(0);
    opacity: 1;
  }
}

.mobile-nav-item {
  display: block;
  padding: 12px 24px;
  font-size: 16px;
  color: var(--text-color);

  &:hover, &.router-link-active {
    color: var(--primary-color);
    background-color: var(--background-color);
  }
}

@media (max-width: 768px) {
  .header-nav {
    display: none;
  }

  .header-mobile-nav-btn {
    display: flex;
  }

  .mobile-nav {
    display: block;
  }
}
</style>