|
|||||||
|
|
|
![]() |
|
|
Strumenti |
|
|
#1 |
|
Member
Iscritto dal: Nov 2005
Città: Torino
Messaggi: 289
|
[Javascript] Validare più form con un'unica funzione
Sto cercando di render il più generiche possibili alcune funzioni.
Ho alcune pagine con dei form con 2 o pocopiù campi da inviare ad altre pagine. Con una funzione javascript (ctrl_form(val1,val2)) che si trova in un file esterno (funzioni.js) controllo che i campi non siano vuoti. Se non ci sono errori faccio eseguire document.form1.submit(); Ovviamente ciò funziona solo con il form chiamato form1. Se modificassi la funzione in modo da far passare anche il nome del form (ctrl_form(val1,val2,'nomeform')), c'è un modo per poter fare il submit di tale form? Ciò mi permetterebbe di usare una sola funzione per validare una serie di form.
__________________
Toshiba Satellite A100-926: Intel Core 2 Duo T7200, 2 GB ram ddr2, ATI MOBILITY RADEON X1600 512 MB Hypermemory (256 MB+256 MB) |
|
|
|
|
|
#2 |
|
Senior Member
Iscritto dal: Sep 2007
Messaggi: 754
|
Puoi usare una funzione che ha come parametro solo il nome della form poi cicli su tutti gli elementi della form facendoti gli appositi controlli poi con document.getElementByID(idForm).submit() effettui il submit della form se tutto va bene.
__________________
http://www.tevigroup.it/ |
|
|
|
|
|
#3 | ||
|
Senior Member
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
|
Quote:
Quote:
Ma se e come fare tale funzione, dipende da come sono fatti i tuoi form e dai vincoli che intendi applicare ai campi. Insomma .... senza sapere come sono fatti e cosa vuoi controllare, neanche io saprei dirti di più.
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%) |
||
|
|
|
|
|
#4 | |
|
Member
Iscritto dal: Nov 2005
Città: Torino
Messaggi: 289
|
Quote:
Codice:
<form name="utente" method="post" action="dati_post.php?>
<table>
<tr>
<td>username</td>
<td><input type="text" name="nome"></td>
</tr>
<tr>
<td>password</td>
<td><input type="text" name="cognome"></td>
</tr>
</table>
<input type="button" onClick="javascript:ctrlForm(document.utente.nome.value,document.utente.cognome.value,'login');" value="invia">
</form>
Codice:
function ctrlForm(val1,val2,nomeform)
{
if(val1=="" || val2=="")
{
alert("Non hai inserito i dati");
}
else
{
document.utente.submit();
}
}
Come già detto prima, se avessi un altro form che invia 2 dati (tipo indirizzo e città), potrei usare la stessa funzione, passando però il nome del form diverso (per esempio chiamato recapito)
__________________
Toshiba Satellite A100-926: Intel Core 2 Duo T7200, 2 GB ram ddr2, ATI MOBILITY RADEON X1600 512 MB Hypermemory (256 MB+256 MB) |
|
|
|
|
|
|
#5 |
|
Senior Member
Iscritto dal: Sep 2007
Messaggi: 754
|
Codice:
function submitForm(idForm){
document.getelementById(idform).submit();
}
__________________
http://www.tevigroup.it/ |
|
|
|
|
|
#6 | |
|
Member
Iscritto dal: Nov 2005
Città: Torino
Messaggi: 289
|
Quote:
Non vorrei che occorre aggiunger qualcos'altro (ho notato che Safari non accetta alert("bla bla"); ma vuole document.alert("bla bla");
__________________
Toshiba Satellite A100-926: Intel Core 2 Duo T7200, 2 GB ram ddr2, ATI MOBILITY RADEON X1600 512 MB Hypermemory (256 MB+256 MB) |
|
|
|
|
|
|
#7 |
|
Senior Member
Iscritto dal: Sep 2007
Messaggi: 754
|
A me su Firefox funge..prova un po questo
Codice:
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=ISO-8859-1">
<title>Insert title here</title>
<script language="javascript" type="text/javascript">
function validateForm(obj){
document.getElementById(obj).submit();
return false;
}
</script>
</head>
<body>
<form name="frm" id="frm" action="http://www.google.it" method="POST" onsubmit="return validateForm('frm');">
<input type="submit" value="ok">
</form>
</body>
</html>
__________________
http://www.tevigroup.it/ |
|
|
|
|
|
#8 | |
|
Member
Iscritto dal: Nov 2005
Città: Torino
Messaggi: 289
|
Quote:
Tra l'altro ho notato che l'alert su Safari funziona anche senza document., non so perché prima non funionava.
__________________
Toshiba Satellite A100-926: Intel Core 2 Duo T7200, 2 GB ram ddr2, ATI MOBILITY RADEON X1600 512 MB Hypermemory (256 MB+256 MB) |
|
|
|
|
|
|
#9 |
|
Senior Member
Iscritto dal: Sep 2007
Messaggi: 754
|
Evidentemente gli avrò messo paura
Buon lavoro
__________________
http://www.tevigroup.it/ |
|
|
|
|
|
#10 |
|
Senior Member
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
|
Se si vuole fare una funzione di validazione abbastanza "generica", si può fare così (nota, ho testato solo campi di tipo input text):
Codice:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=iso-8859-1">
<title>Prova</title>
<script type="text/javascript">
<!--
function validate (form_obj)
{
var i, control;
for (i = 0; i < form_obj.elements.length; i++)
{
control = form_obj.elements[i];
if (control.tagName == "INPUT" && control.getAttribute ("type") == "text")
{
if (control.value == "")
{
alert ("Non hai inserito tutti i dati");
return false;
}
}
}
return true;
}
//-->
</script>
</head>
<body>
<form method="post" name="form1" action="#" onsubmit="return validate(this)">
<input type="text" name="val1" value=""><br>
<input type="text" name="val2" value=""><br>
<input type="submit" value="INVIA">
</form>
<br>
<form method="post" name="form2" action="#" onsubmit="return validate(this)">
<input type="text" name="val1" value=""><br>
<input type="text" name="val2" value=""><br>
<input type="text" name="val3" value=""><br>
<input type="text" name="val4" value=""><br>
<input type="submit" value="INVIA">
</form>
</body>
</html>
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%) |
|
|
|
|
|
#11 |
|
Member
Iscritto dal: Nov 2005
Città: Torino
Messaggi: 289
|
La tua funzione risulta molto più generica della mia, grazie.
Io, che avevo un file con le funzioni javascript e un altro file con il codice html, per adesso ho risolto così: pagina delle funzioni javascript: Codice:
function submitForm(val1,val2,idForm)
{
if(val1=="" || val2=="")
{
alert("Non hai inserito i dati");
}
else
{
document.getElementById(idForm).submit();
}
}
Codice:
<form name="utente" id="utente" method="post" onsubmit="return submitForm(document.utente.nome.value,document.utente.cognome.value,'utente')" action="dati_post.php?r=<?php echo(r());?>">
<table>
<tr>
<td>username</td>
<td><input type="text" name="nome"></td>
</tr>
<tr>
<td>password</td>
<td><input type="text" name="cognome"></td>
</tr>
</table>
<input type="submit" value="invia">
</form>
Grazie per l'aiuto.
__________________
Toshiba Satellite A100-926: Intel Core 2 Duo T7200, 2 GB ram ddr2, ATI MOBILITY RADEON X1600 512 MB Hypermemory (256 MB+256 MB) Ultima modifica di Fabiorayden : 27-09-2007 alle 14:34. Motivo: mancava del codice nella pagina html |
|
|
|
|
|
#12 | |
|
Senior Member
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
|
Quote:
Sì ma dovresti far ritornare il true/false dalla funzione.
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%) |
|
|
|
|
|
|
#13 |
|
Member
Iscritto dal: Nov 2005
Città: Torino
Messaggi: 289
|
In effetti senza return la funzione javascript ha poco senso, per di più così com'era, generava su IE 2 submit
Questa è la versione corretta (tra l'altro non ho nebbeno bisogno di passare il nome del form): Codice:
function submitForm(val1,val2)
{
if(val1=="" || val2=="")
{
alert("Non hai inserito i dati");
return false;
}
else
{
return true;
}
}
__________________
Toshiba Satellite A100-926: Intel Core 2 Duo T7200, 2 GB ram ddr2, ATI MOBILITY RADEON X1600 512 MB Hypermemory (256 MB+256 MB) |
|
|
|
|
| Strumenti | |
|
|
Tutti gli orari sono GMT +1. Ora sono le: 16:53.




















