CardIndex.vue 2.0 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576
  1. <template>
  2. <el-container direction="vertical">
  3. <el-tabs type="border-card" style="height: 100%;" v-model="selectedTab">
  4. <el-tab-pane label="Поиск"></el-tab-pane>
  5. <el-tab-pane label="Автор"></el-tab-pane>
  6. <el-tab-pane label="Книга"></el-tab-pane>
  7. <el-tab-pane label="История"></el-tab-pane>
  8. <keep-alive>
  9. <router-view></router-view>
  10. </keep-alive>
  11. </el-tabs>
  12. </el-container>
  13. </template>
  14. <script>
  15. //-----------------------------------------------------------------------------
  16. import Vue from 'vue';
  17. import Component from 'vue-class-component';
  18. import _ from 'lodash';
  19. const rootRoute = '/cardindex';
  20. const tab2Route = [
  21. '/cardindex/search',
  22. '/cardindex/card',
  23. '/cardindex/book',
  24. '/cardindex/history',
  25. ];
  26. let lastActiveTab = null;
  27. export default @Component({
  28. watch: {
  29. selectedTab: function(newValue, oldValue) {
  30. lastActiveTab = newValue;
  31. this.setRouteByTab(newValue);
  32. },
  33. curRoute: function(newValue, oldValue) {
  34. this.setTabByRoute(newValue);
  35. },
  36. },
  37. })
  38. class CardIndex extends Vue {
  39. selectedTab = null;
  40. mounted() {
  41. this.setTabByRoute(this.curRoute);
  42. }
  43. setTabByRoute(route) {
  44. const t = _.indexOf(tab2Route, route);
  45. if (t >= 0) {
  46. if (t !== this.selectedTab)
  47. this.selectedTab = t.toString();
  48. } else {
  49. if (route == rootRoute && lastActiveTab !== null)
  50. this.setRouteByTab(lastActiveTab);
  51. }
  52. }
  53. setRouteByTab(tab) {
  54. const t = Number(tab);
  55. if (tab2Route[t] !== this.curRoute) {
  56. this.$router.replace(tab2Route[t]);
  57. }
  58. }
  59. get curRoute() {
  60. const m = this.$route.path.match(/^(\/[^\/]*\/[^\/]*).*$/i);
  61. return (m ? m[1] : this.$route.path);
  62. }
  63. }
  64. //-----------------------------------------------------------------------------
  65. </script>
  66. <style scoped>
  67. </style>