Lorsque vous travaillez avec des formulaires en ligne, vous pouvez rencontrer un problème ennuyeux : la redoutable boîte de dialogue « Confirmer la resoumission du formulaire ». Après avoir soumis un formulaire avec des données précieuses saisies par l'utilisateur, l'actualisation de la page peut déclencher cette boîte de dialogue, invitant les utilisateurs à confirmer leurs intentions et pouvant conduire à des soumissions en double.
Ce problème se produit car les données du formulaire sont toujours mises en cache par le navigateur. Lors de l'actualisation de la page, le navigateur détecte que le formulaire a été précédemment soumis et tente d'alerter l'utilisateur d'une éventuelle nouvelle soumission afin d'éviter des actions en double accidentelles.
Pour éviter cette boîte de dialogue gênante, vous pouvez implémenter une solution simple : remplacer le comportement par défaut du navigateur par du code JavaScript. En incluant l'extrait de code suivant dans le code HTML de la page rechargée, vous pouvez demander au navigateur de remplacer l'état actuel par un nouvel état propre, effaçant ainsi la soumission précédente du formulaire :
<code class="javascript">if ( window.history.replaceState ) { window.history.replaceState( null, null, window.location.href ); }</code>
Ce code utilise le 'replaceState ()' pour créer une nouvelle entrée dans l'historique du navigateur, en écrasant l'entrée actuelle. Par conséquent, lorsque l'utilisateur actualise la page, le navigateur reconnaît l'absence de données du formulaire précédent et n'affiche pas la boîte de dialogue « Confirmer la resoumission du formulaire ».
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!