Home.vue 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859
  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. </transition>
  19. <el-backtop target=".content"></el-backtop>
  20. </div>
  21. </div>
  22. </el-main>
  23. </el-container>
  24. </el-container>
  25. </template>
  26. <script>
  27. import vHead from './Header.vue';
  28. import vSidebar from './Sidebar.vue';
  29. import vTags from './Tags.vue';
  30. import bus from './bus';
  31. export default {
  32. data() {
  33. return {
  34. tagsList: [],
  35. collapse: false,
  36. };
  37. },
  38. components: {
  39. vHead,
  40. vSidebar,
  41. vTags,
  42. },
  43. created() {
  44. bus.$on('collapse-content', msg => {
  45. this.collapse = msg;
  46. });
  47. // 只有在标签页列表里的页面才使用keep-alive,即关闭标签之后就不保存到内存中了。
  48. bus.$on('tags', msg => {
  49. let arr = [];
  50. for (let i = 0, len = msg.length; i < len; i++) {
  51. msg[i].name && arr.push(msg[i].name);
  52. }
  53. this.tagsList = arr;
  54. });
  55. },
  56. };
  57. </script>