AppHeader.vue 2.7 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118
  1. <template>
  2. <div style="position: relative;height: 5rem;">
  3. <nav class="header-box" :class="{'visible':visible}">
  4. <img class="logo" src="./../assets/image/logo.png"/>
  5. <router-link to="/home">
  6. <div class="header-item">
  7. <i class="icon-mall-gongnengguanli"></i>首页
  8. </div>
  9. </router-link>
  10. <router-link to="/noticeCenter">
  11. <div class="header-item">
  12. <i v-if="userInfo.unreadNum==0" class="el-icon-message-solid"></i>
  13. <el-badge v-else :value="userInfo.unreadNum" :max="99" class="item">
  14. <i class="el-icon-message-solid"></i>
  15. </el-badge>
  16. 消息中心
  17. </div>
  18. </router-link>
  19. <!-- <router-link to="/pointsRank">
  20. <div class="header-item">
  21. <i class="el-icon-trophy"></i>积分排行
  22. </div>
  23. </router-link> -->
  24. <div class="userInfo flex-center">
  25. <el-avatar fit="fill" :size="50" :src="avatar"></el-avatar>
  26. <div class="nameAndIntegral">
  27. <div>姓名: {{ userInfo.userName }}</div>
  28. <div>积分: <span class="blue">{{ userInfo.surplusIntegral }}</span></div>
  29. </div>
  30. </div>
  31. </nav>
  32. </div>
  33. </template>
  34. <script>
  35. import { mapGetters } from 'vuex'
  36. export default {
  37. props:['visible'],
  38. data() {
  39. return {};
  40. },
  41. computed: {
  42. // 将 getter 映射到当前组件的计算属性
  43. ...mapGetters(['userInfo','avatar'])
  44. },
  45. created() {},
  46. methods: {},
  47. }
  48. </script>
  49. <style>
  50. .logo{
  51. position: absolute;
  52. left: 80px;
  53. width: 160px;
  54. }
  55. .userInfo{
  56. position: absolute;
  57. right: 80px;
  58. }
  59. .flex-center{
  60. display: flex;
  61. justify-content: center;
  62. align-items: center;
  63. }
  64. .nameAndIntegral{
  65. margin-left: 10px;
  66. font-size: 14px;
  67. color: #252933;
  68. line-height: px;
  69. line-height: 23px;
  70. }
  71. .blue {
  72. color: #1e80ff;
  73. }
  74. .header-box {
  75. display: flex;
  76. justify-content: center;
  77. align-items: center;
  78. position: fixed;
  79. top: 0;
  80. left: 0;
  81. right: 0;
  82. background: #fff;
  83. border-bottom: 1px solid #f1f1f1;
  84. color: #909090;
  85. height: 5rem;
  86. z-index: 250;
  87. transition: all .2s;
  88. transform: translate3d(0,-100%,0);
  89. }
  90. .header-item {
  91. display: flex;
  92. justify-content: center;
  93. align-items: center;
  94. flex-direction: column;
  95. padding: 0 120px;
  96. }
  97. nav a {
  98. font-weight: bold;
  99. color: #515767;
  100. }
  101. nav a.route-active {
  102. color: #1e80ff;
  103. }
  104. .header-item i {
  105. font-size: 30px;
  106. margin-bottom: 5px;
  107. }
  108. .header-box.visible{
  109. transform: translateZ(0);
  110. }
  111. </style>