ZZJ
2022-07-28 783f64d66b344e6a478c140b1f3e5804f27f5173
src/components/IndexHeader.vue
@@ -3,14 +3,14 @@
    <div class="header" :class="{ showBox: isShow, disOpacity: !opacity }">
      <!-- 右侧 -->
      <div class="left">
        <img class="logo" src="/images/index/LOGO.png" alt="" />
        <div class="title">工业物联网平台</div>
        <div class="label"><router-link to="/">首页</router-link></div>
        <div class="label">云服务</div>
        <div class="label">
          <router-link to="/equipmentManagement">管理中心</router-link>
        </div>
        <div class="label">应用商城</div>
        <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" @click="$router.push('/manageCenter')">管理中心</div>
        <div class="label" @click="$router.push('/product')">应用商城</div>
      </div>
      <!-- 左侧 -->
@@ -19,10 +19,13 @@
          placeholder="请输入关键词"
          v-model="keyWord"
          @focus="showInputBox(true)"
          :class="{ Unlogin: !userInfo }"
        >
          <div class="iconList" slot="suffix">
            <i class="search iconfont" v-if="!isShow">&#xe607;</i>
            <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
            >
@@ -30,21 +33,30 @@
        </el-input>
        <!-- 未登录情况 -->
        <div class="headerLogin" v-if="!userInfo">
          <router-link to="/login"> 登录</router-link>
        <div
          class="headerLogin"
          v-if="!userInfo"
          @click="$router.push('/login')"
        >
          登录
        </div>
        <div class="register" v-if="!userInfo">
          <router-link to="/register"> 免费注册 </router-link>
        <div
          class="register"
          v-if="!userInfo"
          @click="$router.push('/register')"
        >
          免费注册
        </div>
        <!-- 已登录情况 -->
        <img
          class="userImg"
          src="/images/index/默认头像-01.png"
          src="/images/index/8.jpg"
          alt=""
          v-if="userInfo"
          @mouseenter="showUserBox"
          @mouseleave="hiddenUserBox"
          style="border-radius: 50%"
        />
      </div>
    </div>
@@ -58,14 +70,14 @@
    >
      <div class="userName">{{ userInfo.username }}</div>
      <ul>
        <li class="money">
        <!--   <li class="money">
          <div class="label">余额</div>
          <div class="content">
            <span class="button">充值</span>
            <span class="number">¥4900.82</span>
            <span class="number">¥0</span>
          </div>
        </li>
 -->
        <li class="personal">
          <div class="label">
            <router-link to="/personalCenter">个人中心</router-link>
@@ -77,40 +89,47 @@
        </li>
        <li>
          <div class="label">订单管理</div>
          <div class="label" @click="jump(0)">订单管理</div>
        </li>
        <li>
        <!--  <li>
          <div class="label">产品续费</div>
        </li>
        </li> -->
        <li>
        <!--  <li>
          <div class="label">未读消息</div>
        </li> -->
        <li>
          <div class="label" @click="jump(0, 1)">未支付订单</div>
        </li>
        <li>
          <div class="label">未支付订单</div>
        </li>
        <li>
          <div class="label">管理中心</div>
          <div class="label">
            <router-link to="/manageCenter">管理中心</router-link>
          </div>
        </li>
      </ul>
      <div class="logOut" @click="logOut">退出登录</div>
    </div>
    <!-- 输入下拉框 -->
    <div class="inputBox" v-if="isShowBox">
    <div class="inputBox" :class="{ Unlogin: !userInfo }" v-if="isShowBox">
      <div class="hotKey">
        <div class="title">热门搜索</div>
        <ul class="keyCard">
          <li class="keyItem" 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>
      </div>
      <div class="historyKey">
      <!-- <div class="historyKey">
        <div class="title colorLight">历史搜索</div>
        <ul class="keyCard">
@@ -122,7 +141,7 @@
            {{ item }}
          </li>
        </ul>
      </div>
      </div> -->
    </div>
    <!-- 遮罩层 -->
@@ -152,7 +171,7 @@
    return {
      keyWord: "", //输入框内容
      isShow: false, //显示下拉框
      hotKeyArr: ["算法", "智能AI", "云服务", "管理中心", "实时音视频", "短信"], //热门关键词
      hotKeyArr: ["打电话", "离岗", "睡岗", "入侵", "离岗", "安全帽"], //热门关键词
      historyKeyArr: ["云服务", "算法", "管理服务", "应用"], //历史关键词
      isShowBox: false, //输入下拉框
      userInfo: null, //用户信息
@@ -165,6 +184,7 @@
    showInputBox(toggle) {
      this.isShow = toggle;
      this.isShowBox = toggle;
      this.keyWord = "";
      this.$emit("showInputBox", toggle);
    },
@@ -180,7 +200,7 @@
      const _this = this;
      this.UserTimer = setTimeout(() => {
        _this.isShowUserBox = false;
      }, 100);
      }, 200);
    },
    logOut() {
@@ -198,6 +218,36 @@
          duration: 2500,
          offset: 57,
        });
      });
    },
    jump(id, type) {
      if (type) {
        sessionStorage.setItem("type", type);
      }
      this.$router.push({
        path: "/personalCenter",
        query: {
          id: id,
        },
      });
    },
    search() {
      this.$router.push({
        path: "/product",
        query: {
          keyWord: this.keyWord,
        },
      });
    },
    jumpToSearch(keyWord) {
      this.$router.push({
        path: "/product",
        query: {
          keyWord,
        },
      });
    },
  },
@@ -222,10 +272,12 @@
    .logo {
      margin: 0 7px 0 20px;
      cursor: pointer;
    }
    .title {
      margin-right: 10px;
      cursor: pointer;
    }
    .label {
@@ -304,6 +356,9 @@
      .label {
        color: #3d3d3d;
        &:hover {
          color: #0065ff;
        }
      }
    }
    .right {
@@ -332,10 +387,15 @@
  &.showBox .right .el-input {
    position: absolute;
    z-index: 4;
    top: 0;
    right: 158px;
    top: -7px;
    right: 88px;
    width: 300px;
    background-color: #fff;
    &.Unlogin {
      right: 158px;
    }
    ::v-deep input {
      width: 300px;
      background-color: #fff;
@@ -353,12 +413,17 @@
  box-sizing: border-box;
  position: absolute;
  top: 62px;
  right: 158px;
  right: 88px;
  padding: 12px 20px 8px 20px;
  width: 300px;
  background-color: #fff;
  border-top: 1px solid rgb(204, 204, 204);
  z-index: 4;
  &.Unlogin {
    top: 52px;
    right: 158px;
  }
  .hotKey,
  .historyKey {
@@ -402,12 +467,12 @@
.userBox {
  box-sizing: border-box;
  position: absolute;
  z-index: 3;
  z-index: 10;
  right: 20px;
  top: 64px;
  padding: 0 20px;
  width: 240px;
  height: 427px;
  height: 327px;
  background-color: #fff;
  box-shadow: 0px 4px 12px rgba(96, 100, 106, 0.12);
  border-radius: 4px;
@@ -419,7 +484,7 @@
  }
  ul {
    height: 300px;
    height: 200px;
    border-top: 1px solid #e9ebee;
    border-bottom: 1px solid #e9ebee;
@@ -461,8 +526,12 @@
  .logOut {
    margin-top: 20px;
    font-size: 16px;
    color: #0065ff;
    color: #3d3d3d;
    cursor: pointer;
    &:hover {
      color: #0065ff;
    }
  }
}
</style>