2 Commits 3ff4a8fae7 ... eb9f96a3af

Autor SHA1 Mensagem Data
  未来全栈 eb9f96a3af Merge branch 'master' of http://git.fmode.cn:3000/csdn1233/s202226701049 10 meses atrás
  未来全栈 87ff4e0586 fix: alertCtrl 10 meses atrás

+ 28 - 21
AIart-app/src/app/tab1/tab1.page.ts

@@ -10,6 +10,8 @@ import { ExploreContainerComponent } from '../explore-container/explore-containe
 import { Router } from '@angular/router';
 import { CloudUser } from 'src/lib/ncloud';
 import { openUserLoginModal } from 'src/lib/user/model-user-login/model-user-login.component';
+import { AlertController } from '@ionic/angular';
+
 import { CategoryModalComponent } from 'src/app/category-modal/category-modal.component';
 
 interface Slide {
@@ -27,8 +29,7 @@ interface Slide {
     IonHeader, IonToolbar, IonTitle, IonContent, ExploreContainerComponent,
     IonSearchbar, IonIcon, IonTabButton, IonTabs, IonTabBar, IonLabel, IonNav, IonImg,
     IonSegmentView, IonSegment, IonSegmentButton, IonSegmentContent, IonThumbnail, IonButton,
-    IonRippleEffect, IonBackButton
-  ],
+    IonRippleEffect, IonBackButton]
 })
 export class Tab1Page implements OnInit, OnDestroy {
   slides: Slide[] = [
@@ -79,7 +80,8 @@ export class Tab1Page implements OnInit, OnDestroy {
 
   constructor(
     private router: Router,
-    private modalCtrl: ModalController
+    private modalCtrl: ModalController,
+    private alertCtrl: AlertController  // 注入 AlertController
   ) { }
 
   ngOnInit() {
@@ -159,26 +161,31 @@ export class Tab1Page implements OnInit, OnDestroy {
   async checkLoginAndNavigate(path: string) {
     const currentUser = new CloudUser();
     if (!currentUser.id) {
-      const alert = document.createElement('ion-alert');
-      alert.header = '需要登录';
-      alert.message = '请先登录后再使用此功能';
-      alert.buttons = [
-        {
-          text: '取消',
-          role: 'cancel'
-        },
-        {
-          text: '去登录',
-          handler: async () => {
-            const user = await openUserLoginModal(this.modalCtrl);
-            if (user) {
-              this.router.navigate([path]);
+      console.log("用户ID不存在");
+
+      // 使用 AlertController 来创建和显示弹窗
+      const alert = await this.alertCtrl.create({
+        header: '需要登录',
+        message: '请先登录后再使用此功能',
+        buttons: [
+          {
+            text: '取消',
+            role: 'cancel'
+          },
+          {
+            text: '去登录',
+            handler: async () => {
+              const user = await openUserLoginModal(this.modalCtrl);
+              if (user) {
+                this.router.navigate([path]);
+              }
             }
           }
-        }
-      ];
-      document.body.appendChild(alert);
-      await alert.present();
+        ]
+      });
+
+      console.log("显示弹窗");
+      await alert.present();  // 弹窗显示
     } else {
       this.router.navigate([path]);
     }

+ 5 - 5
AIart-app/src/app/tabs/tabs.page.html

@@ -1,27 +1,27 @@
 <ion-tabs>
   <ion-tab-bar slot="bottom">
     <ion-tab-button tab="tab1" href="/tabs/tab1">
-      <ion-icon aria-hidden="true" name="home-outline"></ion-icon>
+      <ion-icon name="home-outline"></ion-icon>
       <ion-label>首页</ion-label>
     </ion-tab-button>
 
     <ion-tab-button tab="tab2" href="/tabs/tab2">
-      <ion-icon aria-hidden="true" name="book-outline"></ion-icon>
+      <ion-icon name="book-outline"></ion-icon>
       <ion-label>学习计划</ion-label>
     </ion-tab-button>
 
     <ion-tab-button tab="tab4" href="/tabs/tab4" class="main-tab">
-      <ion-icon aria-hidden="true" name="bulb-outline"></ion-icon>
+      <ion-icon name="bulb-outline"></ion-icon>
       <ion-label>AI助手</ion-label>
     </ion-tab-button>
 
     <ion-tab-button tab="tab3" href="/tabs/tab3">
-      <ion-icon aria-hidden="true" name="people-outline"></ion-icon>
+      <ion-icon name="people-outline"></ion-icon>
       <ion-label>社区</ion-label>
     </ion-tab-button>
 
     <ion-tab-button tab="tab5" href="/tabs/tab5">
-      <ion-icon aria-hidden="true" name="person-outline"></ion-icon>
+      <ion-icon name="person-outline"></ion-icon>
       <ion-label>我的</ion-label>
     </ion-tab-button>
   </ion-tab-bar>