亚洲国产日韩欧美一区二区三区,精品亚洲国产成人av在线,国产99视频精品免视看7,99国产精品久久久久久久成人热,欧美日韩亚洲国产综合乱

Table des matières
Causes courantes et solutions aux sauts de page après des requêtes asynchrones
1. Empêcher le comportement de navigation dans les pages par défaut
2. Actualisez la page actuelle une fois la demande de récupération réussie.
Point de terminaison du back-end PHP
Résumer
Maison développement back-end tutoriel php Tutoriel sur la prévention des sauts de page et l'actualisation de la page actuelle après avoir utilisé la requête Fetch POST asynchrone

Tutoriel sur la prévention des sauts de page et l'actualisation de la page actuelle après avoir utilisé la requête Fetch POST asynchrone

Oct 15, 2025 pm 04:12 PM

Tutoriel sur la prévention des sauts de page et l'actualisation de la page actuelle après avoir utilisé la requête Fetch POST asynchrone

Lorsqu'ils utilisent l'API ??fetch?? de JavaScript pour effectuer des requêtes POST asynchrones, les développeurs rencontrent souvent le problème que la page saute de manière inattendue au point de terminaison de l'API une fois la requête terminée. Cet article détaillera comment empêcher le comportement de navigation par défaut dans les pages en définissant le type de bouton sur ? bouton ? ou en utilisant ? event.preventDefault() ? dans l'événement de soumission de formulaire, et en utilisant la méthode ? location.reload() ? pour actualiser la page actuelle une fois la requête ? fetch ? réussie, obtenant ainsi une expérience utilisateur transparente.

Causes courantes et solutions aux sauts de page après des requêtes asynchrones

Lorsque vous utilisez l'API fetch pour envoyer des données au backend, en particulier lors de la mise à jour des données via des requêtes POST, nous espérons généralement qu'une fois les données mises à jour, l'utilisateur restera toujours sur la page actuelle et que le contenu de la page reflétera les dernières modifications des données. Cependant, une frustration courante est que le navigateur peut accéder automatiquement à l'URL cible de la requête POST (c'est-à-dire le point de terminaison de l'API) une fois la requête terminée. Il ne s’agit généralement pas d’un comportement souhaité car il interrompt l’expérience utilisateur pour les applications d’une seule page ou les mises à jour partielles.

Les principales raisons de ce comportement sont :

  1. Le comportement par défaut du bouton?: L'élément
  2. Soumission de formulaire débloquée?: même si le bouton ne se trouve pas dans le formulaire ou est créé dynamiquement via JavaScript, la page peut sauter si son comportement finit par simuler une soumission de formulaire.

Pour résoudre ce problème, nous devons suivre deux étapes principales?: empêcher la navigation dans les pages et actualiser la page actuelle une fois la demande réussie.

1. Empêcher le comportement de navigation dans les pages par défaut

Selon le cas d'utilisation du bouton, il existe deux manières principales d'empêcher la navigation dans les pages?:

Méthode 1?:?spécifiez explicitement le type de bouton en tant que bouton

Si votre bouton est utilisé pour déclencher une fonction JavaScript plut?t que de soumettre l'intégralité du formulaire, la méthode la plus simple consiste à définir son attribut de type sur "bouton". Cela indiquera clairement au navigateur que le bouton ne doit pas déclencher le comportement traditionnel de soumission de formulaire.

Exemple HTML?:

 <!-- La balise span d&#39;origine peut déclencher indirectement certains comportements, nous nous concentrons sur le bouton interne -->
<span onclick="addGuestName(this)">
    <button class="addPaxName btn btn-xs btn-warning" type="button">AJOUTER</button>
</span>

En ajoutant type="button", cliquer sur ce bouton ne fera plus sauter la page.

Méthode 2?:?empêcher le comportement par défaut dans l'événement de soumission de formulaire (event.preventDefault())

Si votre bouton se trouve réellement à l'intérieur d'une balise

et que vous souhaitez gérer la logique de soumission via JavaScript plut?t que de laisser le navigateur effectuer la soumission du formulaire par défaut, vous devez alors utiliser event.preventDefault() dans l'écouteur d'événement de soumission du formulaire.

Exemple HTML (en supposant que le bouton se trouve dans un formulaire)?:

 

Exemple JavaScript?:

 document.getElementById('guestForm').addEventListener('submit', function(event) {
    event.preventDefault(); // Empêche le comportement de soumission par défaut du formulaire // Appelez votre fonction de récupération asynchrone ici // updateGuestName(paxid, name);
});

Dans votre code d'origine, le bouton déclenche la fonction updateGuestName via addEventListener('click', ...), et le bouton est créé dynamiquement. Si le bouton n'est pas explicitement spécifié avec type="button" et que son élément parent ou ancêtre est un

, il peut toujours être traité comme un bouton de soumission. Par conséquent, l’approche la plus s?re consiste à garantir que les boutons créés dynamiquement ont également type="button" défini.

Modifiez la partie de la fonction addGuestName qui crée le bouton?:

 fonction addGuestName(obj) {
  const itemClicked = obj;
  const paxid = obj.id;
  const addPaxNameButton = itemClicked.nextElementSibling; // Supposons qu'il s'agisse d'un bouton AJOUTER existant addPaxNameButton.style.display = 'inline-block';
  // Assurez-vous que le bouton créé ici ou un bouton existant a type="button"
  // S'il est créé dynamiquement, vous pouvez le définir ici // addPaxNameButton.setAttribute('type', 'button'); // Si vous devez modifier le bouton existant, tapez var addPaxNameField = document.createElement('input');
  addPaxNameField.setAttribute('type', 'text');
  addPaxNameField.setAttribute('nom', 'visitorNameSurname[]');
  addPaxNameField.setAttribute('placeholder', 'Entrez le nom et le prénom');
  itemClicked.parentNode.insertBefore(addPaxNameField, itemClicked.nextSibling);
  addPaxNameField.setAttribute("obligatoire", "obligatoire");

  // Ecoute l'événement click du bouton ADD addPaxNameButton.addEventListener('click', () => {
    const nom = addPaxNameField.value?;
    updateGuestName(paxid, nom);
    // Ici, vous pouvez envisager de supprimer la zone de saisie ou de désactiver le bouton permettant de fournir des commentaires à l'utilisateur});
}

2. Actualisez la page actuelle une fois la demande de récupération réussie.

Après avoir empêché les sauts de page, nous devons actualiser la page actuelle pour afficher les dernières données une fois la demande de récupération terminée avec succès et les données mises à jour. Ceci peut être réalisé grace à la méthode location.reload().

La méthode location.reload() rechargera le document actuel. Il possède un paramètre booléen facultatif qui, s'il est défini sur true, oblige le navigateur à recharger la page depuis le serveur au lieu de la charger depuis le cache. Normalement, aucun paramètre ou valeur false ne suffira.

Intégrez location.reload() dans votre fonction asynchrone?:

 fonction asynchrone updateGuestName (paxid, nom) {
  const paxIDbody = JSON.stringify({ pxid : paxid, nom : nom }); // Méthode de stringification JSON plus s?re console.log("PaxID:", paxIDbody);
  essayer {
    paramètres const = {
      méthode : "POST",
      en-têtes?:?{
        "Content-type": "application/json; charset=UTF-8"
      },
      corps?: paxIDbody,
    }?;
    réponse const = attendre la récupération (
      "/change-name.php",
      paramètres
    );

    if (!response.ok) { // Vérifiez le code d'état de la réponse HTTP throw new Error(`HTTP error! status: ${response.status}`);
    }

    const data = attendre réponse.json();
    console.log("DONNéES?: ", données);

    // Une fois la requête réussie et les données traitées, actualisez la page actuelle location.reload();

  } attraper (erreur) {
    console.erreur("ERREUR?: ", erreur); // Utilisez console.error pour imprimer les erreurs // Vous pouvez afficher des messages d'erreur à l'utilisateur ici}
}

Choses à noter?:

  • Gestion des erreurs?: dans la demande d'extraction, l'attribut réponse.ok peut être utilisé pour vérifier si le code d'état de la réponse HTTP est compris entre 200 et 299. Il s'agit d'une méthode de gestion des erreurs plus robuste que de simplement compter sur try...catch, car fetch ne générera pas d'erreur en cas d'erreurs HTTP (telles que 404, 500), uniquement en cas de problèmes de réseau.
  • Commentaires de l'utilisateur?: avant l'actualisation de la page, vous pouvez envisager de donner un bref retour à l'utilisateur, par exemple en affichant le message "Mise à jour..." ou "Mise à jour réussie?!" pour améliorer l’expérience utilisateur.
  • JSON.stringify?:?l'utilisation de JSON.stringify() pour créer un corps de requête JSON est plus s?re et plus robuste que l'épissage manuel de cha?nes, et peut éviter d'éventuelles erreurs de format et problèmes d'injection.

Point de terminaison du back-end PHP

Votre point de terminaison backend PHP est le bon moyen de renvoyer des données JSON, car il s'agit d'une interface API et ne doit pas tenter de redirections de pages.

 <?php header(&#39;Content-type:application/json;charset=utf-8&#39;);
// Supposons que les variables $status et $message ont été définies en fonction des résultats de l&#39;opération de base de données $myObj=new \stdClass();
$monObj->statut = $statut;
$monObj->message = $message;
$monJSON = json_encode($monObj);
echo $monJSON?;
?>

Ce code PHP est une réponse API JSON standard, il n'entra?ne pas de navigation dans le navigateur, le problème vient donc du comportement par défaut des boutons frontend.

Résumer

Pour réussir à rester sur la page actuelle et à la rafra?chir après une requête POST de récupération asynchrone, la clé est?:

  1. Empêcher la navigation par défaut?: assurez-vous que le bouton qui déclenche la demande de récupération possède l'attribut type="button", ou si le bouton se trouve dans un formulaire, utilisez event.preventDefault() pour empêcher le comportement de soumission par défaut du formulaire.
  2. Actualisation de la page?: une fois la demande d'extraction terminée avec succès et les données de réponse traitées, location.reload() est appelé pour actualiser la page actuelle afin d'afficher le dernier état des données.

Grace aux étapes ci-dessus, vous serez en mesure de créer un processus de mise à jour des données asynchrone plus convivial et fonctionnel.

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefa?on, veuillez contacter admin@php.cn

Outils d'IA chauds

Undress AI Tool

Undress AI Tool

Images de déshabillage gratuites

Undresser.AI Undress

Undresser.AI Undress

Application basée sur l'IA pour créer des photos de nu réalistes

AI Clothes Remover

AI Clothes Remover

Outil d'IA en ligne pour supprimer les vêtements des photos.

Stock Market GPT

Stock Market GPT

Recherche d'investissement basée sur l'IA pour des décisions plus intelligentes

Outils chauds

Bloc-notes++7.3.1

Bloc-notes++7.3.1

éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise

SublimeText3 version chinoise

Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1

Envoyer Studio 13.0.1

Puissant environnement de développement intégré PHP

Dreamweaver CS6

Dreamweaver CS6

Outils de développement Web visuel

SublimeText3 version Mac

SublimeText3 version Mac

Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Comment vérifier si une adresse e-mail est valide en PHP? Comment vérifier si une adresse e-mail est valide en PHP? Sep 21, 2025 am 04:07 AM

Usefilter_var () tovalidateemailsyntaxandcheckdnsrr () toverifydomainmxrecords.example: $ email = "user@example.com"; if (f ilter_var ($ e-mail, filter_validate_email) && checkdnsrr (explosage ('@', $ e-mail) [1], 'mx')) {echo "ValidAndDeliverableMail & Qu

MySQL Aggrégation conditionnelle: Instruction de cas d'utilisation pour mettre en ?uvre le résumé de la condition et le comptage des champs MySQL Aggrégation conditionnelle: Instruction de cas d'utilisation pour mettre en ?uvre le résumé de la condition et le comptage des champs Sep 16, 2025 pm 02:39 PM

Cet article explique en profondeur comment utiliser les instructions de cas pour effectuer une agrégation conditionnelle dans MySQL pour atteindre la sommation conditionnelle et le comptage de champs spécifiques. Grace à un cas de système d'abonnement pratique, il montre comment calculer dynamiquement la durée totale et le nombre d'événements en fonction de l'état des enregistrements (tels que "end" et "annuler"), surmontant ainsi les limites des fonctions de somme traditionnelles qui ne peuvent pas répondre aux besoins d'une agrégation conditionnelle complexe. Le tutoriel analyse en détail l'application des instructions de cas en détail et souligne l'importance de la fusion lorsqu'il s'agit des valeurs nulles possibles de la jointure gauche.

Comment faire une copie profonde ou un clone d'un objet en PHP? Comment faire une copie profonde ou un clone d'un objet en PHP? Sep 21, 2025 am 12:30 AM

UseUnserialize (serialize ($ obj)) FordopcopyingwhenallDataisSerializable; Sinon, implémentez__Clone () TomanuallyDuplicatesedObjectsAndavoidSharedReferences.

Comment fusionner deux tableaux en php? Comment fusionner deux tableaux en php? Sep 21, 2025 am 12:26 AM

UseArray_merge () toCombineArrays, écrasant leduplicatestringKeysAndreIndexingNumericKeys; ForsimplecCaTencatenation, en particulierInphp5.6, usethesplatoperator [... $ array1, ... $ array2].

Comment utiliser des espaces de noms dans un projet PHP? Comment utiliser des espaces de noms dans un projet PHP? Sep 21, 2025 am 01:28 AM

NamespacesInphporganizEcodeAndPreventnamingConflictsBygroupingClasses, Interfaces, Functions et ConstantsunSunSaspecificName.2.DefineanamespaceusingTheNamesPaceSpaceKeyWordAtTopofaFile, suiviByTheNamesPacename, Suchasapp \ Controlers...USUSEUSEKEYWORDTOI

Comment mettre à jour un enregistrement dans une base de données avec PHP? Comment mettre à jour un enregistrement dans une base de données avec PHP? Sep 21, 2025 am 04:47 AM

ToupDateAdatabasereCorDinPhp, FirstConnectUsingPDoOrmysQLi, theNusepreparedStationStoExECUSEASECURSQLUPDATEQUERY.example: $ pdo = newPDO ("MySql: host = localhost; dbname = votre_database", $ username, $ mot de passe); $ sql = "dameussem =.

Quelles sont les méthodes magiques en PHP et fournissent un exemple de `__Call () 'et` __get ()'. Quelles sont les méthodes magiques en PHP et fournissent un exemple de `__Call () 'et` __get ()'. Sep 20, 2025 am 12:50 AM

La méthodiette () méthodiste axée sur le point de réviser la mise en ?uvre de l'inscription, ce qui permet de faire de la maintenance à la qualité de qualité et

Comment obtenir l'extension de fichier en php? Comment obtenir l'extension de fichier en php? Sep 20, 2025 am 05:11 AM

UsePathinfo ($ nom de fichier, pathinfo_extension) togetThefileExtension; itreliabblyHandlesMultipledototsEdGasases, renvoyantTheExtension (par exemple, "pdf") oranemptystringefNoneExists.

See all articles