App.vue 1.49 KB
<template>
  <div class="app-container">
    <el-container>
      <el-aside width="180px" class="sidebar">
        <div class="logo-area">
          <span>云物联网平台</span>
        </div>
        <el-menu
          :default-active="currentRoute"
          class="sidebar-menu"
          background-color="#304156"
          text-color="#bfcbd9"
          active-text-color="#409eff"
          :router="true"
        >
          <el-menu-item index="/smart-light">
            <el-icon><Monitor /></el-icon>
            <span>智能灯</span>
          </el-menu-item>
          <el-menu-item index="/energy">
            <el-icon><Lightning /></el-icon>
            <span>能耗</span>
          </el-menu-item>
        </el-menu>
      </el-aside>
      <el-main class="main-content">
        <router-view />
      </el-main>
    </el-container>
  </div>
</template>

<script setup>
import { computed } from 'vue'
import { useRoute } from 'vue-router'

const route = useRoute()
const currentRoute = computed(() => route.path)
</script>

<style scoped>
.app-container {
  height: 100vh;
  overflow: hidden;
}
.sidebar {
  background-color: #304156;
  color: #fff;
}
.logo-area {
  padding: 18px 16px;
  color: #fff;
  font-size: 15px;
  font-weight: bold;
  text-align: center;
  border-bottom: 1px solid rgba(255,255,255,0.08);
  background-color: #263445;
}
.sidebar-menu {
  border-right: none !important;
  padding-top: 8px;
}
.main-content {
  background-color: #f0f2f5;
  padding: 0;
  overflow-y: auto;
}
</style>