Maison >développement back-end >tutoriel php >Comment puis-je utiliser AJAX et PHP pour soumettre efficacement plusieurs entrées de formulaire à une base de données sans actualisation de page ?

Comment puis-je utiliser AJAX et PHP pour soumettre efficacement plusieurs entrées de formulaire à une base de données sans actualisation de page ?

Linda Hamilton
Linda Hamiltonoriginal
2024-12-04 07:02:10494parcourir

How can I use AJAX and PHP to efficiently submit multiple form inputs to a database without page refresh?

AJAX et PHP pour saisir plusieurs entrées de formulaire dans une base de données

Dans cet article, nous explorerons comment utiliser AJAX et PHP pour saisir plusieurs entrées de formulaire dans une base de données. Comme vous êtes nouveau sur AJAX, nous nous concentrerons sur la compréhension des concepts et de l'application d'AJAX dans ce contexte.

Pour commencer, considérons l'exemple de formulaire suivant généré en PHP :

<?php

   echo "<form method='post'>";

   $i=1;

    while($i <= $num_to_enter){

    $form_output .= "First Name:

    <input>

Ce formulaire génère dynamiquement plusieurs ensembles de champs de saisie en fonction de la sélection de l'utilisateur (« $num_to_enter »). Notre objectif est d'utiliser AJAX pour envoyer les données de ces champs de saisie à un script PHP pour l'insertion dans la base de données.

Concernant la fonction AJAX que vous avez fournie, le problème principal est l'utilisation incorrecte du caractère '&' lorsque concaténer les chaînes de données. De plus, la boucle « while » en dehors de l'appel AJAX entraîne l'envoi de données vides.

Voici une version corrigée de la fonction AJAX :

function MyFunction(){

  var i = 1;
  var x = $('#num_to_enter').val(); // Get the number of form sets

  var dataString = ''; // Initialize an empty data string

  // Iterate through the number of form sets
  while (i <= x){

    // Concatenate the data string using JavaScript's += operator
    dataString += "fname[" + i + "]=" + $('#fname[' + i + ']').val() + "&";
    dataString += "lname[" + i + "]=" + $('#lname[' + i + ']').val() + "&";
    dataString += "email[" + i + "]=" + $('#email[' + i + ']').val() + "&";

    i++;
  }

  // Remove the trailing '&' character from the data string
  dataString = dataString.substr(0, dataString.length - 1);

  // Send the data via AJAX to the 'process.php' script
  $.ajax({
    url: 'process.php', 
    type: 'POST', 
    data: dataString, // The concatenated data string is passed here
    success: function(data){

      // Handle the response from 'process.php'
      // Your code goes here
    },
    complete: function(){
      // Perform tasks after the AJAX request is complete
      // Your code goes here
    }
  });
}

Dans cette fonction corrigée, nous concaténons de manière appropriée les données dans une seule chaîne ("dataString") et transmettez-la comme paramètre "data" dans l'AJAX appel.

Pour le script PHP ("process.php"), nous pouvons avoir quelque chose comme ceci :

<?php
  if($_SERVER['REQUEST_METHOD'] === 'POST') {

    // Parse the data from the POST request
    parse_str($_POST['data'], $formData);

    // Extract the individual data sets
    $fnames = $formData['fname'];
    $lnames = $formData['lname'];
    $emails = $formData['email'];

    // Initialize the success flag
    $success = true;

    // Perform the database insertions
    for ($i = 0; $i < count($fnames); $i++) {

      // Insert into database
      // ...

      // Check if any insertion failed
      if(!...){
        $success = false;
        break;
      }
    }

    // Return the success flag as JSON
    echo json_encode(array('success' => $success));
  }
?>

Dans ce script PHP, nous analysons les données POST, extrayons l'individu ensembles de données et parcourez-les pour effectuer des insertions dans la base de données. Si une insertion échoue, l'indicateur « succès » est défini sur false. Enfin, nous renvoyons l'indicateur « succès » au format JSON à l'appel AJAX.

Cette approche vous permet de soumettre plusieurs ensembles de formulaires de manière asynchrone via AJAX et de gérer les insertions de base de données dans le script PHP, offrant ainsi une expérience utilisateur plus fluide sans rafraîchir la page.

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