CONNEXION
  • RetourJeux
    • Tests
    • Soluces
    • Previews
    • Sorties
    • Hit Parade
    • Les + attendus
    • Tous les Jeux
  • RetourActu
    • Culture Geek
    • Astuces
    • Réalité Virtuelle
    • Rétrogaming
    • Toutes les actus
  • RetourHigh-Tech
    • Actus JVTECH
    • Bons plans
    • Tutoriels
    • Tests produits High-Tech
    • Guides d'achat High-Tech
    • JVTECH
  • RetourVidéos
    • A la une
    • Gaming Live
    • Vidéos Tests
    • Vidéos Previews
    • Gameplay
    • Trailers
    • Chroniques
    • Replay Web TV
    • Toutes les vidéos
  • RetourForums
    • Hardware PC
    • PS5
    • Switch
    • Xbox Series
    • Overwatch 2
    • FUT 23
    • League of Legends
    • Genshin Impact
    • Tous les Forums
  • PC
  • PS5
  • Xbox Series
  • PS4
  • One
  • Switch
  • Wii U
  • iOS
  • Android
  • MMO
  • RPG
  • FPS
En ce moment Genshin Impact Valhalla Breath of the wild Animal Crossing GTA 5 Red dead 2
Etoile Abonnement RSS

Sujet : [Angular] rediriger vers page non trouvée

DébutPage précedente
1
Page suivantePage suivante
Pseudo supprimé
Niveau 20
04 juillet 2022 à 22:01:45

Bonjour :) j'ai mis en place un système de redirection lorsqu'un path n'existe pas.

 export const appRoutes: Routes = [
  { path: '', component: HomeComponent },
  { path: 'afficher/:dossier/:fichier.txt', component: FileComponent, runGuardsAndResolvers: 'always' },
  { path: 'not-found', component: FourOhFourComponent},
  { path: '**', redirectTo: '/not-found' }
]

Cela fonctionne en général, sauf dans un cas précis: lorsqu'un fichier txt (dont le nom est passé en paramètre dans l'URL) n'existe pas, c'est-à-dire dans le cas suivant:

http://localhost:port/afficher/dossier/fichier.txt

Ce fichier txt est stocké dans le dossier assets, et je vais le chercher via une requête (avec un fetch) pour ensuite l'afficher dans mon component.

Cependant, si je mets un fichier qui n'existe pas, le component s'affiche bel et bien, avec une page blanche. J'aimerais que la page soit redirigée vers mon component gérant l'erreur (/not-found). Qu'est-ce que je dois faire pour ça ?

:d) En attendant, j'ai bricolé ceci, dans le constructeur:

fetch('assets/text/'
      +this.route.snapshot.params['dossier']
      +'/'
      +this.route.snapshot.params['fichier'])
      .then(response => response.text())
      .then(data => {
        if(data.includes('Cannot GET')){
          this.router.navigate(['/not-found']);
        }
      });

ça marche mais j'avoue que ça fait un peu dégueulasse :rire: car on voit dans un premier temps le component (avec page blanche) s'afficher, puis ensuite on voit dans un second temps la redirection vers /not-found.

Des suggestions? :hap:

Message édité le 04 juillet 2022 à 22:02:52 par
DébutPage précedente
1
Page suivantePage suivante
Répondre
Prévisu
?
Victime de harcèlement en ligne : comment réagir ?
Infos 0 connecté(s)

Gestion du forum

Modérateurs : Thymotep
Contacter les modérateurs - Règles du forum

Sujets à ne pas manquer

La vidéo du moment