TopHeader.vue 2.1 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586878889909192939495969798
  1. <template>
  2. <header :class="'mui-bar mui-bar-nav '+headerClass" :style="headerStyle">
  3. <template>
  4. <a v-if="titleDownShow" class="mui-title" @click="downAction">{{pageTitle}}<span class="mui-icon mui-icon-arrowdown"></span></a>
  5. <a v-else class="mui-title">{{pageTitle}}</a>
  6. </template>
  7. <a v-if="leftShow" class="mui-icon mui-icon-left-nav mui-pull-left" :routeName="routeName" @click="goBack"></a>
  8. <a v-if="rightLink.show" @click="doRightLink" class="fyy-bar mui-pull-right">
  9. <span :class="'mui-icon '+(rightLink.icon?(rightLink.icon.indexOf('mui-')>-1?'':'iconfont'):'')+' '+rightLink.icon" :style="rightLink.style">
  10. <span class="header-right-wz">
  11. {{rightLink.title}}<i></i>
  12. </span>
  13. <span v-if="systemMessageNum>0" class="mui-badge mui-badge-danger jp-badge" v-text="systemMessageNum"></span>
  14. </span>
  15. </a>
  16. </header>
  17. </template>
  18. <script>
  19. export default {
  20. name: 'TopHeader',
  21. props: {
  22. headerClass: {
  23. require: false,
  24. default: '',
  25. },
  26. headerStyle: {
  27. require: false,
  28. default: '',
  29. },
  30. routeName: {
  31. require: false,
  32. default: '',
  33. },
  34. pageTitle: {
  35. require: false,
  36. default: '',
  37. },
  38. leftShow: {
  39. require: false,
  40. default: true,
  41. },
  42. rightLink: {
  43. require: false,
  44. type: Object,
  45. default: () => ({
  46. show: false,
  47. to: '',
  48. icon: '',
  49. style: '',
  50. title: ''
  51. }),
  52. },
  53. doRightLink: {
  54. require: false,
  55. type: Function,
  56. },
  57. systemMessageNum: {
  58. require: false,
  59. default: 0
  60. },
  61. titleDownShow: {
  62. require: false,
  63. default: false,
  64. },
  65. downAction: {
  66. require: false,
  67. type: Function,
  68. }
  69. },
  70. methods: {
  71. //返回上一层
  72. goBack() {
  73. if (this.routeName) {
  74. this.$router.push({
  75. name: this.routeName
  76. })
  77. } else {
  78. this.$router.go(-1);
  79. }
  80. },
  81. },
  82. }
  83. </script>
  84. <style scoped src="@/assets/css/xpgj.css"></style>
  85. <style scoped>
  86. .jp-badge {
  87. font-size: 12px !important;
  88. margin-left: 0 !important;
  89. line-height: 1.4 !important;
  90. top: 5px !important;
  91. left: 50% !important;
  92. background-color: #F7D046 !important;
  93. color: #000 !important;
  94. }
  95. </style>