index.vue 1.4 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344
  1. <script lang="ts" setup>
  2. import type { LoginExpiredModeType } from '@vben/types';
  3. import { preferences, updatePreferences } from '@vben/preferences';
  4. import { Button } from 'ant-design-vue';
  5. import { getMockStatus } from '#/apis';
  6. defineOptions({ name: 'LoginExpired' });
  7. async function handleClick(type: LoginExpiredModeType) {
  8. const loginExpiredMode = preferences.app.loginExpiredMode;
  9. updatePreferences({ app: { loginExpiredMode: type } });
  10. await getMockStatus('401');
  11. updatePreferences({ app: { loginExpiredMode } });
  12. }
  13. </script>
  14. <template>
  15. <div class="p-5">
  16. <div class="card-box p-5">
  17. <h1 class="text-xl font-semibold">登录过期演示</h1>
  18. <div class="text-foreground/80 mt-2">
  19. 接口请求遇到401状态码时,需要重新登录。有两种方式:
  20. <div>1.转到登录页,登录成功后跳转回原页面</div>
  21. <div>
  22. 2.弹出重新登录弹窗,登录后关闭弹窗,不进行任何页面跳转(刷新后调整登录页面)
  23. </div>
  24. </div>
  25. </div>
  26. <div class="card-box mt-5 p-5">
  27. <div class="mb-3 text-lg font-semibold">跳转登录页面方式</div>
  28. <Button type="primary" @click="handleClick('page')"> 点击触发 </Button>
  29. </div>
  30. <div class="card-box mt-5 p-5">
  31. <div class="mb-3 text-lg font-semibold">登录弹窗方式</div>
  32. <Button type="primary" @click="handleClick('modal')"> 点击触发 </Button>
  33. </div>
  34. </div>
  35. </template>