mark
2022-10-21 1fe240406526b9b6256664559d3d2bec9250135c
src/components/IndexHeader.vue
@@ -1,19 +1,19 @@
<template>
  <div class="IndexHeader">
    <div class="header" :class="{ showBox: isShow, disOpacity: !opacity }">
      <!-- 右侧 -->
      <!-- 左侧 -->
      <div class="left">
        <router-link to="/">
          <img class="logo" src="/images/index/LOGO.png" alt="" />
        </router-link>
        <div class="title" @click="$router.push('/')">工业互联网平台</div>
        <div class="label" @click="$router.push('/')">首页</div>
        <!-- <div class="label">云服务</div> -->
        <div class="label">云服务</div>
        <div class="label" @click="$router.push('/manageCenter')">管理中心</div>
        <div class="label" @click="$router.push('/product')">应用商城</div>
      </div>
      <!-- 左侧 -->
      <!-- 右侧 -->
      <div class="right">
        <el-input
          placeholder="请输入关键词"
@@ -23,28 +23,16 @@
        >
          <div class="iconList" slot="suffix">
            <i class="search iconfont" v-if="!isShow">&#xe607;</i>
            <i class="search iconfont" @click="search" v-if="isShow"
              >&#xe607;</i
            >
            <i class="del iconfont" v-if="isShow" @click="showInputBox(false)"
              >&#xe60f;</i
            >
            <i class="search iconfont" @click="search" v-if="isShow">&#xe607;</i>
            <i class="del iconfont" v-if="isShow" @click="showInputBox(false)">&#xe60f;</i>
          </div>
        </el-input>
        <!-- 未登录情况 -->
        <div
          class="headerLogin"
          v-if="!userInfo"
          @click="$router.push('/login')"
        >
        <div class="headerLogin" v-if="!userInfo" @click="$router.push('/login')">
          登录
        </div>
        <div
          class="register"
          v-if="!userInfo"
          @click="$router.push('/register')"
        >
        <div class="register" v-if="!userInfo" @click="$router.push('/register')">
          免费注册
        </div>
@@ -62,12 +50,7 @@
    </div>
    <!-- 用户下拉框 -->
    <div
      class="userBox"
      v-if="userInfo && isShowUserBox"
      @mouseenter="showUserBox"
      @mouseleave="hiddenUserBox"
    >
    <div class="userBox" v-if="userInfo && isShowUserBox" @mouseenter="showUserBox" @mouseleave="hiddenUserBox">
      <div class="userName">{{ userInfo.username }}</div>
      <ul>
        <!--   <li class="money">
@@ -83,9 +66,7 @@
            <router-link to="/personalCenter">个人中心</router-link>
          </div>
          <div class="content">
            <span class="iconfont">&#xe605;</span> 已实名认证
          </div>
          <div class="content"><span class="iconfont">&#xe605;</span> 已实名认证</div>
        </li>
        <li>
@@ -118,12 +99,7 @@
      <div class="hotKey">
        <div class="title">热门搜索</div>
        <ul class="keyCard">
          <li
            class="keyItem"
            @click="jumpToSearch(item)"
            v-for="(item, index) in hotKeyArr"
            :key="index"
          >
          <li class="keyItem" @click="jumpToSearch(item)" v-for="(item, index) in hotKeyArr" :key="index">
            {{ item }}
          </li>
        </ul>
@@ -150,19 +126,19 @@
</template>
<script>
import { logout } from "@/api/login";
import { logout } from "@/api/login"
export default {
  props: {
    opacity: {
      type: Boolean,
      default: true,
    },
      default: true
    }
  },
  name: "Header",
  created() {
    //尝试从session中拿用户信息
    this.userInfo = JSON.parse(sessionStorage.getItem("userInfo"));
    this.userInfo = JSON.parse(sessionStorage.getItem("userInfo"))
    /*  document.addEventListener("click", () => {
      this.showUserBox = false;
    }); */
@@ -176,82 +152,82 @@
      isShowBox: false, //输入下拉框
      userInfo: null, //用户信息
      isShowUserBox: false, //用户信息弹层
      UserTimer: null, // 控制弹层的定时器
    };
      UserTimer: null // 控制弹层的定时器
    }
  },
  methods: {
    // 控制输入框box
    showInputBox(toggle) {
      this.isShow = toggle;
      this.isShowBox = toggle;
      this.keyWord = "";
      this.$emit("showInputBox", toggle);
      this.isShow = toggle
      this.isShowBox = toggle
      this.keyWord = ""
      this.$emit("showInputBox", toggle)
    },
    //控制用户信息box
    showUserBox() {
      if (this.UserTimer) {
        clearTimeout(this.UserTimer);
        this.UserTimer = null;
        clearTimeout(this.UserTimer)
        this.UserTimer = null
      }
      this.isShowUserBox = true;
      this.isShowUserBox = true
    },
    hiddenUserBox() {
      const _this = this;
      const _this = this
      this.UserTimer = setTimeout(() => {
        _this.isShowUserBox = false;
      }, 200);
        _this.isShowUserBox = false
      }, 200)
    },
    logOut() {
      logout().then(() => {
        sessionStorage.removeItem("loginedInfo");
        sessionStorage.removeItem("expires_in");
        sessionStorage.removeItem("userInfo");
        sessionStorage.removeItem("loginedInfo")
        sessionStorage.removeItem("expires_in")
        sessionStorage.removeItem("userInfo")
        this.$router.push({
          path: "/login",
        });
          path: "/login"
        })
        this.$notify({
          title: "提示",
          type: "success",
          message: "退出成功!",
          duration: 2500,
          offset: 57,
        });
      });
          offset: 57
        })
      })
    },
    jump(id, type) {
      if (type) {
        sessionStorage.setItem("type", type);
        sessionStorage.setItem("type", type)
      }
      this.$router.push({
        path: "/personalCenter",
        query: {
          id: id,
        },
      });
          id: id
        }
      })
    },
    search() {
      this.$router.push({
        path: "/product",
        query: {
          keyWord: this.keyWord,
        },
      });
          keyWord: this.keyWord
        }
      })
    },
    jumpToSearch(keyWord) {
      this.$router.push({
        path: "/product",
        query: {
          keyWord,
        },
      });
    },
  },
};
          keyWord
        }
      })
    }
  }
}
</script>
<style lang="scss" scoped>
@@ -259,10 +235,10 @@
  display: flex;
  justify-content: space-between;
  align-items: center;
  height: 62px;
  height: 50px;
  width: 100%;
  min-width: 1280px;
  background-color: rgba(255, 255, 255, 0.25);
  background-color: #1f2a3e;
  color: #fff;
  font-size: 14px;
@@ -276,12 +252,12 @@
    }
    .title {
      margin-right: 10px;
      margin-right: 30px;
      cursor: pointer;
    }
    .label {
      margin: 0 20px;
      margin-right: 20px;
      cursor: pointer;
    }
  }
@@ -346,16 +322,22 @@
  &:hover,
  &.showBox,
  &.disOpacity {
    background-color: #fff;
    background-color: #1f2a3e;
    .left {
      font-family: PingFang SC Regular;
      font-size: 14px;
      font-weight: normal;
      line-height: 20px;
      letter-spacing: 0px;
      color: #ffffff;
      .title {
        color: #3d3d3d;
        // color: #3d3d3d;
        font-weight: 700;
      }
      .label {
        color: #3d3d3d;
        // color: #3d3d3d;
        &:hover {
          color: #0065ff;
        }
@@ -534,4 +516,4 @@
    }
  }
}
</style>
</style>