Die Route kann dem Popup-Dialogfeld in vue.js nicht zugewiesen werden
P粉786800174
P粉786800174 2023-09-05 23:14:08
0
1
608
<p>Ich versuche, einem benutzerdefinierten Popup, das ich mit der Dialogkomponente in vue.js erstellt habe, eine Route zuzuweisen, habe aber Probleme damit, es zum Laufen zu bringen. Ich habe viel vermasselt und bin ehrlich gesagt verwirrt, wie ich das hinbekomme. Das ist meine Routendatei: </p> <pre class="brush:php;toolbar:false;">routes: [ { Pfad: "/", Name: „Landung“, Komponente: LandingView, Kinder: [ { Pfad: "/register", Komponente: Registrierungsformular, }, ], },</pre> <p>Ich habe eine Anmeldeseite und verwende innerhalb dieser Anmeldeseite die RegistrationForm-Komponente, die in einer benutzerdefinierten Dialogkomponente enthalten ist, die ich wie folgt erstellt habe: </p> <pre class="brush:php;toolbar:false;"><teleport to="body"> <dialog-modal v-if="isOpenRegister" @close="isOpenRegister = false"> <Anmeldeformular @open-login="(isOpenRegister = false), (isOpenLogin = true)" @close-dialog="isOpenRegister = false" /> </dialog-modal> </teleport></pre> <p>Ich möchte dem Popup nur dann eine Route zuweisen, wenn der Benutzer darauf klickt. Wenn der Benutzer also auf die Schaltfläche „Registrieren“ klickt und das Popup aktiviert wird, möchte ich, dass es http://localhost:5173/register lautet, anstatt jetzt keine Route zu haben, da es nur http://localhost:5173 ist. Es tut mir leid, wenn dies eine verwirrende Frage ist. Versuchen Sie bitte, sie so gut wie möglich zu erklären. Vielen Dank im Voraus! </p>
P粉786800174
P粉786800174

Antworte allen(1)
P粉790187507

您应该在某些方法内处理重定向,例如:

<teleport to="body">
  <dialog-modal v-if="isOpenRegister" @close="isOpenRegister = false">
    <RegistrationForm
      @open-login="openRegister"
      @close-dialog="isOpenRegister = false"
    />
  </dialog-modal>
</teleport>

<script>
 methods: {
   openRegister() {
     this.$router.push({ path: '/register' })
     // other method logic
   }
 }
</script>
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage