DeleteAccount.vue 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138
  1. <template>
  2. <div class="page-container">
  3. <!-- 导航栏 -->
  4. <div class="nav-bar">
  5. <div class="nav-left" @click="$router.back()">
  6. <svg width="24" height="24" viewBox="0 0 24 24" fill="none">
  7. <path d="M15 18L9 12L15 6" stroke="#333" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"/></svg>
  8. </div>
  9. <div class="nav-title">注销账号</div>
  10. <div class="nav-right"></div>
  11. </div>
  12. <div class="content">
  13. <p class="intro-text">注销账户后,您可能需要考虑以下几点:</p>
  14. <div class="text-block">
  15. <span class="block-title">数据无法恢复:</span>
  16. 一旦注销账户,您在该账户中的所有数据可能会永久丢失。因此,请务必在注销前做好数据备份。
  17. </div>
  18. <div class="text-block">
  19. <span class="block-title">影响其他服务:</span>
  20. 有些账户可能与其他服务相关联,例如通过社交媒体账户登录的应用。如果您注销了这些账户,可能会影响您使用的其他服务。
  21. </div>
  22. <div class="text-block">
  23. <span class="block-title">等待期:</span>
  24. 一些平台在您申请注销后,可能会设置一个等待期。在此期间,您仍然可以取消注销请求,恢复账户。
  25. </div>
  26. <div class="text-block">
  27. <span class="block-title">隐私设置:</span>
  28. 即使您注销了某些账户,您在其他平台上的信息仍然可能被保留。定期检查您的隐私设置,确保您的信息安全。
  29. </div>
  30. <div class="text-block summary-text">
  31. 注销账户是保护个人隐私和安全的重要步骤。在决定注销之前,确保备份所有重要的数据,了解注销的具体步骤和后果。每个平台的注销流程可能有所不同,因此在操作时请务必仔细阅读相关说明。
  32. </div>
  33. </div>
  34. <!-- 底部按钮 -->
  35. <div class="footer-action">
  36. <button class="delete-btn" @click="handleDelete">注销</button>
  37. </div>
  38. </div>
  39. </template>
  40. <script setup>
  41. import { useRouter } from 'vue-router';
  42. // import { showConfirmDialog, showToast } from 'vant'; // 如果有 Vant
  43. const router = useRouter();
  44. const handleDelete = () => {
  45. // 模拟确认弹窗
  46. const isConfirmed = confirm('确定要注销账号吗?此操作无法撤销。');
  47. if (isConfirmed) {
  48. console.log('执行注销逻辑...');
  49. alert('申请已提交');
  50. router.push('/');
  51. }
  52. };
  53. </script>
  54. <style scoped>
  55. .page-container {
  56. min-height: 100vh;
  57. background-color: #fff;
  58. display: flex; flex-direction: column;
  59. }
  60. /* 导航栏 */
  61. .nav-bar {
  62. display: flex; justify-content: space-between; align-items: center;
  63. height: 44px; padding: 0 16px; background: #fff;
  64. position: sticky; top: 0; z-index: 10;
  65. }
  66. .nav-title { font-size: 18px; font-weight: 600; color: #333; }
  67. .nav-left, .nav-right { width: 40px; display: flex; align-items: center; }
  68. /* 内容区域 */
  69. .content {
  70. padding: 16px 20px 100px; /* 底部留出按钮空间 */
  71. flex: 1;
  72. overflow-y: auto;
  73. }
  74. .intro-text {
  75. font-size: 14px; color: #666;
  76. margin-bottom: 20px;
  77. line-height: 1.6;
  78. }
  79. .text-block {
  80. font-size: 14px;
  81. color: #666;
  82. line-height: 1.8; /* 较大的行高,增加可读性 */
  83. margin-bottom: 20px;
  84. text-align: justify; /* 两端对齐,使大段文字边缘整齐 */
  85. }
  86. /* 重点文字加深颜色 */
  87. .block-title {
  88. color: #333;
  89. font-weight: 500;
  90. }
  91. /* 底部总结段落 */
  92. .summary-text {
  93. margin-top: 30px;
  94. }
  95. /* 底部固定按钮区 */
  96. .footer-action {
  97. position: fixed;
  98. bottom: 0; left: 0; right: 0;
  99. padding: 10px 20px 30px; /* 适配 iPhone 底部安全区 */
  100. background: #fff;
  101. /* 可选:加个上边框或阴影让层次更分明 */
  102. /* border-top: 1px solid #eee; */
  103. }
  104. .delete-btn {
  105. width: 100%;
  106. height: 48px;
  107. background: #E02F44; /* 警示红 */
  108. color: #fff;
  109. border: none;
  110. border-radius: 24px;
  111. font-size: 16px;
  112. font-weight: 600;
  113. cursor: pointer;
  114. }
  115. .delete-btn:active {
  116. opacity: 0.9;
  117. }
  118. </style>