Home.vue 1.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960
  1. <template>
  2. <el-container>
  3. <el-header style="padding:0;">
  4. <v-head></v-head>
  5. </el-header>
  6. <el-container>
  7. <el-aside width="200px">
  8. <v-sidebar></v-sidebar>
  9. </el-aside>
  10. <el-main>
  11. <div class="content-box" :class="{ 'content-collapse': collapse }">
  12. <v-tags></v-tags>
  13. <div class="content">
  14. <transition name="move" mode="out-in">
  15. <!-- <keep-alive :include="tagsList">
  16. <router-view></router-view>
  17. </keep-alive> -->
  18. <router-view></router-view>
  19. </transition>
  20. <el-backtop target=".content"></el-backtop>
  21. </div>
  22. </div>
  23. </el-main>
  24. </el-container>
  25. </el-container>
  26. </template>
  27. <script>
  28. import vHead from './Header.vue';
  29. import vSidebar from './Sidebar.vue';
  30. import vTags from './Tags.vue';
  31. import bus from './bus';
  32. export default {
  33. data() {
  34. return {
  35. tagsList: [],
  36. collapse: false,
  37. };
  38. },
  39. components: {
  40. vHead,
  41. vSidebar,
  42. vTags,
  43. },
  44. created() {
  45. bus.$on('collapse-content', msg => {
  46. this.collapse = msg;
  47. });
  48. // 只有在标签页列表里的页面才使用keep-alive,即关闭标签之后就不保存到内存中了。
  49. bus.$on('tags', msg => {
  50. let arr = [];
  51. for (let i = 0, len = msg.length; i < len; i++) {
  52. msg[i].name && arr.push(msg[i].name);
  53. }
  54. this.tagsList = arr;
  55. });
  56. },
  57. };
  58. </script>