Newer
Older
KaiFengPC / src / plugins / tab.js
@zhangdeliang zhangdeliang on 23 May 1 KB 初始化项目
  1. import useTagsViewStore from '@/store/modules/tagsView'
  2. import router from '@/router'
  3.  
  4. export default {
  5. // 刷新当前tab页签
  6. refreshPage(obj) {
  7. const { path, query, matched } = router.currentRoute.value;
  8. if (obj === undefined) {
  9. matched.forEach((m) => {
  10. if (m.components && m.components.default && m.components.default.name) {
  11. if (!['Layout', 'ParentView'].includes(m.components.default.name)) {
  12. obj = { name: m.components.default.name, path: path, query: query };
  13. }
  14. }
  15. });
  16. }
  17. return useTagsViewStore().delCachedView(obj).then(() => {
  18. const { path, query } = obj
  19. router.replace({
  20. path: '/redirect' + path,
  21. query: query
  22. })
  23. })
  24. },
  25. // 关闭当前tab页签,打开新页签
  26. closeOpenPage(obj) {
  27. useTagsViewStore().delView(router.currentRoute.value);
  28. if (obj !== undefined) {
  29. return router.push(obj);
  30. }
  31. },
  32. // 关闭指定tab页签
  33. closePage(obj) {
  34. if (obj === undefined) {
  35. return useTagsViewStore().delView(router.currentRoute.value).then(({ lastPath }) => {
  36. return router.push(lastPath || '/index');
  37. });
  38. }
  39. return useTagsViewStore().delView(obj);
  40. },
  41. // 关闭所有tab页签
  42. closeAllPage() {
  43. return useTagsViewStore().delAllViews();
  44. },
  45. // 关闭左侧tab页签
  46. closeLeftPage(obj) {
  47. return useTagsViewStore().delLeftTags(obj || router.currentRoute.value);
  48. },
  49. // 关闭右侧tab页签
  50. closeRightPage(obj) {
  51. return useTagsViewStore().delRightTags(obj || router.currentRoute.value);
  52. },
  53. // 关闭其他tab页签
  54. closeOtherPage(obj) {
  55. return useTagsViewStore().delOthersViews(obj || router.currentRoute.value);
  56. },
  57. // 打开tab页签
  58. openPage(url) {
  59. return router.push(url);
  60. },
  61. // 修改tab页签
  62. updatePage(obj) {
  63. return useTagsViewStore().updateVisitedView(obj);
  64. }
  65. }