Maison >interface Web >js tutoriel >Comment puis-je simuler une soumission de formulaire POST en JavaScript ?

Comment puis-je simuler une soumission de formulaire POST en JavaScript ?

Patricia Arquette
Patricia Arquetteoriginal
2024-12-27 18:20:10283parcourir

How Can I Simulate a POST Form Submission in JavaScript?

Simulation de la soumission d'un formulaire via une requête POST en JavaScript

Lorsque la navigation vers une page différente nécessite une requête POST, les méthodes de soumission de formulaire standard peuvent ne soit pas accessible via JavaScript. Cet article présente une solution pour publier des données de manière dynamique et modifier l'emplacement du navigateur, en émulant le comportement de soumission de formulaire.

Création et soumission de formulaires dynamiques

Pour y parvenir, créez un formulaire de manière dynamique, remplissez-le avec des champs de saisie masqués contenant les paramètres nécessaires et soumettez-le it:

<br>function post(path, params, method='post') {<br> const form = document.createElement('form');<br> form.method = méthode;<br> form.action = chemin;</p>
<p>pour (clé const dans les paramètres) {</p>
<pre class="brush:php;toolbar:false">if (params.hasOwnProperty(key)) {
  const hiddenField = document.createElement('input');
  hiddenField.type = 'hidden';
  hiddenField.name = key;
  hiddenField.value = params[key];

  form.appendChild(hiddenField);
}

}

document.body.appendChild(form);
form.submit();
}

Exemple d'utilisation

À soumettre les données à '/contact/' avec un paramètre 'name' défini sur 'Johnny Bravo' :

<br>post('/contact/', {name : 'Johnny Bravo'} );<br>

Important Remarque

Dans la solution fournie, la vérification « hasOwnProperty » garantit la compatibilité entre les navigateurs et évite les bogues potentiels.

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:
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