From 9cad6a832c786989be620573b09badccfe7e3b51 Mon Sep 17 00:00:00 2001
From: QYF-GitLab1 <1940665526@qq.com>
Date: 星期一, 25 八月 2025 15:11:37 +0800
Subject: [PATCH] 首页头部,样式调整

---
 src/layout/components/headerPage.vue |  138 ++++++++++++++++++++++++++++++----------------
 1 files changed, 90 insertions(+), 48 deletions(-)

diff --git a/src/layout/components/headerPage.vue b/src/layout/components/headerPage.vue
index 9aa7fcd..e1c4cd4 100644
--- a/src/layout/components/headerPage.vue
+++ b/src/layout/components/headerPage.vue
@@ -7,7 +7,7 @@
             () => {
               $router.push({
                 path: '/home',
-              });
+              })
             }
           "
           src="@/assets/images/xiehe/home/Group_303.png"
@@ -15,24 +15,27 @@
       </div>
       <div class="searchBox" v-show="!hideSerch">
         <el-input
-          style="width: 500px; height: 50px"
+          style="width: 500px; height: 36px"
           placeholder="璇疯緭鍏ュ唴瀹�"
-          @change="gotoSearch"
           v-model="searchKey"
           :suffix-icon="Search"
+          @keyup.enter="gotoSearch"
         >
         </el-input>
         <div class="loginInfoBox">
-          <div v-if="!userInfo" class="loginBtnBox">
-            <a
+          <div v-if="!userInfo" class="loginBtnBox" style="width: 200px">
+            <div
+              class="loginBtn"
               @click="
                 () => {
-                  console.log(loginRef.value);
-                  loginRef.logIn();
+                  console.log(loginRef.value)
+                  loginRef.logIn()
                 }
               "
-              >娉ㄥ唽/鐧诲綍</a
             >
+              <el-icon><UserFilled /></el-icon>
+              娉ㄥ唽/鐧诲綍
+            </div>
           </div>
           <div v-else class="userInfoBox">
             <el-dropdown @command="handleCommand">
@@ -44,10 +47,10 @@
               </span>
               <template #dropdown>
                 <el-dropdown-menu>
-                  <el-dropdown-item icon="el-icon-user" command="gotoPersonalCenter"
+                  <el-dropdown-item :icon="Avatar" command="gotoPersonalCenter"
                     >涓汉涓績</el-dropdown-item
                   >
-                  <el-dropdown-item icon="el-icon-switch-button" command="logout"
+                  <el-dropdown-item :icon="SwitchButton" command="logout"
                     >閫�鍑虹櫥褰�</el-dropdown-item
                   >
                 </el-dropdown-menu>
@@ -62,7 +65,8 @@
       <div
         :class="{
           navItem: true,
-          active: $route.fullPath.indexOf(item.path) > -1,
+          // active: $route.fullPath.indexOf(item.path) > -1,
+          active: item.pathList.findIndex((citem) => citem == $route.path) > -1,
         }"
         v-for="(item, index) in navData"
         :key="index"
@@ -75,15 +79,18 @@
 </template>
 
 <script setup lang="ts">
-import login from "./login.vue";
-import { onMounted, ref } from "vue";
-import { Search } from "@element-plus/icons-vue";
-import { useUserStore } from "@/store";
-import { useRouter } from "vue-router";
-const userStore = useUserStore();
-const router = useRouter();
+import login from './login.vue'
+import { onMounted, provide, ref } from 'vue'
+import { Search, Avatar, SwitchButton } from '@element-plus/icons-vue'
+import { useUserStore } from '@/store'
+import { useRouter, useRoute } from 'vue-router'
+import { ElMessage } from 'element-plus'
 
-const loginRef = ref();
+const userStore = useUserStore()
+const router = useRouter()
+const route = useRoute()
+
+const loginRef = ref()
 const props = defineProps({
   hideSerch: {
     type: Boolean,
@@ -93,58 +100,78 @@
     type: Boolean,
     default: false,
   },
-});
+})
 
-let searchKey = ref("");
-let userInfo = ref("");
+let searchKey = ref('')
+let userInfo = ref('')
 const navData = ref([
   {
-    name: "棣栭〉",
-    path: "/home",
+    name: '棣栭〉',
+    path: '/home',
+    pathList: ['/home', '/search'],
   },
   {
-    name: "鏁欒偛鍑虹増",
-    path: "/bookStore",
+    name: '鏁欒偛鍑虹増',
+    path: '/bookStore',
+    pathList: ['/bookStore', '/bookdetail'],
   },
   {
-    name: "璇昏�呮湇鍔�",
-    path: "/teachingServices",
+    name: '璇昏�呮湇鍔�',
+    path: '/teachingServices',
+    pathList: ['/teachingServices'],
   },
   {
-    name: "鍏充簬鎴戜滑",
-    path: "/aboutUs",
+    name: '鍏充簬鎴戜滑',
+    path: '/aboutUs',
+    pathList: ['/aboutUs'],
   },
-]);
+])
 
 onMounted(() => {
-  userInfo.value = userStore.userInfo;
-  console.log(userInfo.value, "userInfo");
-});
+  userInfo.value = userStore.userInfo
+  console.log(userInfo.value, 'userInfo')
+  console.log(route, 'route')
+})
 
-const gotoSearch = () => {};
+const gotoSearch = () => {
+  router.push({
+    path: '/search',
+    query: {
+      key: searchKey.value,
+    },
+  })
+}
 const handleCommand = (item) => {
-  if (item === "gotoPersonalCenter") {
+  if (item === 'gotoPersonalCenter') {
     router.push({
-      path: "/personalCenter",
-    });
+      path: '/personalCenter',
+    })
   }
-  if (item === "logout") {
-    localStorage.clear();
+  if (item === 'logout') {
+    localStorage.clear()
+    userStore.delteUserInfo()
+    userInfo.value = null
     router.push({
-      path: "/home",
-    });
+      path: '/home',
+    })
   }
-};
+}
 const gotoPage = (item) => {
-  router.push(item.path);
-};
+  if (item.path === '/teachingServices') {
+    ElMessage({
+      message: '寤鸿涓�...',
+      type: 'warning',
+    })
+  } else {
+    router.push(item.path)
+  }
+}
 </script>
 
 <style lang="less" scoped>
 .pageHeader {
   width: 100%;
   background-color: #fff;
-  border-bottom: 1px solid #e6e6e6;
   .topBar {
     background: #e6e6e6;
     color: #808080;
@@ -158,11 +185,21 @@
   .loginInfoBox {
     width: 200px;
     margin-left: 20px;
+    .loginBtn {
+      width: 100px;
+      background-color: #144941;
+      height: 36px;
+      line-height: 36px;
+      text-align: center;
+      border-radius: 20px;
+      color: #ffffff;
+      cursor: pointer;
+    }
   }
   .logoBox {
     padding: 25px 0;
     overflow: hidden;
-    max-width: 1200px !important;
+    max-width: 1369px !important;
     .logo {
       float: left;
       height: 66px;
@@ -208,9 +245,14 @@
   }
 }
 </style>
-<style>
+<style scoped>
 .pageHeader .searchBox .el-input-group__prepend {
   background: #fff;
   color: #444;
 }
+::v-deep(.el-input__wrapper) {
+  border-radius: 50px !important;
+  height: 36px;
+  line-height: 36px;
+}
 </style>

--
Gitblit v1.9.1