Maison >développement back-end >tutoriel php >Comment transmettre correctement des variables JavaScript à PHP via Ajax ?
Transmettre des variables Javascript à PHP via Ajax
Le transfert de variables entre JavaScript et PHP est crucial lors de la création d'applications Web interactives. Ajax joue un rôle central dans ce processus, permettant l'échange de données sans recharger la page entière. Cependant, accéder aux variables en PHP peut poser des défis aux débutants.
Problème :
Pour transmettre une variable JavaScript nommée "userID" à PHP, un appel Ajax est utilisé . Le code JavaScript initie la requête Ajax et envoie le "userID" en paramètre :
<code class="javascript">$.ajax({ type: "POST", url: 'logtime.php', data: "userID=" + userID, success: function(data) {...} });</code>
Côté PHP, une variable nommée "$uid" est utilisée pour recevoir le "userID" passé depuis JavaScript. Le code PHP tente d'attribuer la valeur en utilisant ce qui suit :
<code class="php">$uid = isset($_POST['userID']);</code>
Solution :
La principale erreur de ce code réside dans l'utilisation inappropriée du "isset ()" dans le script PHP. "isset()" détermine si une variable ou un élément de tableau a été défini, mais n'attribue pas de valeur. Pour accéder à la variable "userID" envoyée depuis Ajax, la modification suivante est nécessaire :
<code class="php">if(isset($_POST['userID'])) { $uid = $_POST['userID']; }</code>
Transmettre correctement les données avec jQuery :
Dans l'appel JavaScript Ajax, le paramètre data doit être formaté en tant qu'objet pour transmettre correctement la variable :
<code class="javascript">$.ajax({ type: "POST", url: 'logtime.php', data: { userID : userID }, success: function(data) {...} });</code>
Remarque : La fonction "isset()" n'est pas nécessaire ici car la méthode Ajax de jQuery gère la variable vérification de disponibilité automatiquement.
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!