Problema nell'invio dei dati di un form ad uno script AJAX

ducadimantova

Nuovo Utente
30 Ago 2012
31
0
6
Ciao

sono a sottoporvi un banale problema nell'invio, in modalità post, dei dati di un form ad un file JS, che tramite AJAX li invia ad un file PHP per inserirli nel database.

Il mio problema è che non nel momento in cui clicco sul bottone "inserisci" del mio form non ottengo la risposta che mi aspetto, e cioè per adesso la sola verifica dei dati inviati al file php.

Di seguito il contenuto del file "insertarea.js"

Codice:
function inserisci()

{

	
	if (window.XMLHttpRequest)
	  {// code for IE7+, Firefox, Chrome, Opera, Safari
		oXHR=new XMLHttpRequest();
	  }
	else
	  {// code for IE6, IE5
		oXHR=new ActiveXObject("Microsoft.XMLHTTP");
	  }
	
	oXHR.open("POST","engines/engine_inserimento_utenti.php",true);
	oXHR.setRequestHeader("Content-type","application/x-www-form-urlencoded");		
			  
	oXHR.onreadystatechange = function (){                    
		          if(oXHR.readyState == 4){                       
		              if (oXHR.status == 200) {                               
		                  document.getElementById("risposta").innerHTML=oXHR.responseText;
		              }
		          }
		      };
		      
		  var stringa = "nome=" + encodeURIcomponent(document.modulo.nomee.value)  + "&cognome=" 
		  + encodeURIComponent(document.modulo.cognome.value) + "&email=" 
		  + encodeURIComponent(document.modulo.email.value) + "&password=" 
		  + encodeURIComponent(document.modulo.password.value) + "&password2=" 
		  + encodeURIComponent(document.modulo.password2.value)+ "";

			oXHR.send(stringa);

}

Questo riportato sotto è il form (che come potete notare viene stampato da una funzione PHP):

PHP:
echo "
    			
    			
    			<form class='form_admin' method='post' name='modulo'>
    			    			
    			<p class='testo_admin'>Inserisci il nuovo nome utente:</p>
    			
    			<input type='text' name='nome' class='input_admin' />
    			
    			<p class='testo_admin'>Inserisci il cognome del nuovo utente:</p>
    			
    			<input type='text' name='cognome' class='input_admin' />    			
    			
    			<p class='testo_admin'>Inserisci un indirizzo email:</p>
    			
    			<input type='text' name='email' class='input_admin' />
    			
    			<p class='testo_admin'>Inserisci una password per il nuovo utente:</p>
    			
    			<input type='password' name='password' class='input_admin' />
    			
    			<p class='testo_admin'>Ripeti la password:</p>
    			
    			<input type='password' name='password2' class='input_admin'/>
    			
    			<input type='button' value='Inserisci' onClick=\"inserisci()\" class='bottone_admin'/>
    			
    			</form>
    			
    			<div id='risposta'></div>    			
    			
    			";

Il file "engine_inserimento_utenti.php" per ora si limita a stampare quanto riceve nel div con id "risposta":

PHP:
echo $_POST["nome"].$_POST["cognome"].$_POST["email"].$_POST["password"].$_POST["password2"];



Chiedo gentilmente a qualche anima pia un aiuto per risolvere il problema.

Grazie mille!
 
Ultima modifica di un moderatore:
Prima di tutto non vedo perché stampi il form con PHP quando potresti farlo usando HTML. Inoltre ti consiglio di usare jQuery, che rende il tutto molto più semplice ed elegante:
HTML:
<!DOCTYPE html>
<html lang="en">
    <head>
        <title>Form AJAX</title>
        <meta charset="utf-8" />

        <script src="http://code.jquery.com/jquery-latest.js"></script>
        <script>
        $(function() {
            $("#submit").click(function() {
                $.post("engine_inserimento_utenti.php", {
                    nome:      $("#nome").val(),
                    cognome:   $("#cognome").val(),
                    email:     $("#email").val(),
                    password:  $("#password").val(),
                    password2: $("#password2").val()
                }, function(data) {
                    $("#risposta").html(data);
                });
            });
        });
        </script>
    </head>

    <body>
        <form class="form_admin" method="post">
            <p class="testo_admin">Inserisci il nuovo nome utente:</p>
            <input type="text" id="nome" class="input_admin" />

            <p class="testo_admin">Inserisci il cognome del nuovo utente:</p>
            <input type="text" id="cognome" class="input_admin" />

            <p class="testo_admin">Inserisci un indirizzo email:</p>
            <input type="text" id="email" class="input_admin" />

            <p class="testo_admin">Inserisci una password per il nuovo utente:</p>
            <input type="password" id="password" class="input_admin" />

            <p class="testo_admin">Ripeti la password:</p>
            <input type="password" id="password2" class="input_admin" />

            <input type="button" value="Inserisci" id="submit" class="bottone_admin" />
        </form>

        <div id="risposta"></div>
    </body>
</html>
Infine, per le etichette dei campi si usa il tag label, non p.
 
Ultima modifica:
Grazie mille

Grazie mille per la risposta!

Stampo il form in php perchè il mio è un sito dimamico che visualizza un form diverso a seconda delle necessità dell'utente: quello che ho postato è solo una parte di un file più ampio.

Con jquery è sicuramente meglio, tuttavia, dopo essermi abbondantemente scervellato sul problema sarei ancora interessato a capire perchè il file js non funziona :(!!
 
Lo script non sembra funzionare

Ciao Alessandro1997

Lo script che mi hai passato non mi funzia.


Sei sicuro di non aver tralasciato qualcosa? Tipo $(document).ready(...., i vari parametri nella chiamata ajax quali type: "POST"...ecc?
Il tag <script> poi non dovrebbe riportare "type="text/javascript"?

Scusa ma sono abbastanza a digiuno di javascript...

Grazie!
 
Avevo scritto $.ajax invece di $.post, quindi era necessario specificare anche il metodo della chiamata. Ho modificato il post originale, prova ora.

L'attributo type del tag script è di default text/javascript in HTML5, e $() equivale a $(document).ready().
 
Grazie

Confermo: adesso funziona

I miei complimenti :fonzie: (anche per la pazienza)

Grazie mille alessandro1997
 

Discussioni simili