Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Marathon: arriva il Fortnite hardcore
Marathon: arriva il Fortnite hardcore
Marathon è il titolo multiplayer competitivo del momento. Ecco quali sono le caratteristiche di gioco principali, insieme alle nostre prime considerazioni dopo qualche "run" nell'extraction shooter di Bungie
HP Imagine 2026: abbiamo visto HP IQ all’opera, ecco cosa può (e non può) fare
HP Imagine 2026: abbiamo visto HP IQ all’opera, ecco cosa può (e non può) fare
A New York HP ha messo al centro della scena HP IQ, la piattaforma di IA locale da 20 miliardi di parametri. L’abbiamo vista in funzione: è uno strumento che funziona, pensato per un target specifico, con vantaggi reali e limiti altrettanto evidenti
PNY RTX 5080 Slim OC, sembra una Founders Edition ma non lo è
PNY RTX 5080 Slim OC, sembra una Founders Edition ma non lo è
La PNY GeForce RTX 5080 Slim OC si distingue nel panorama delle GPU di fascia alta per il design compatto a due slot, ispirato alla NVIDIA GeForce RTX 5080 Founders Edition. In questo test analizziamo comportamento termico e prestazioni in gioco, valutando se il formato ridotto comprometta o meno l'esperienza complessiva rispetto alle soluzioni più ingombranti presenti sul mercato.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 26-09-2007, 17:34   #1
Fabiorayden
Member
 
L'Avatar di Fabiorayden
 
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)
Fabiorayden è offline   Rispondi citando il messaggio o parte di esso
Old 26-09-2007, 18:04   #2
isAlreadyInUse
Senior Member
 
L'Avatar di isAlreadyInUse
 
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/
isAlreadyInUse è offline   Rispondi citando il messaggio o parte di esso
Old 26-09-2007, 20:23   #3
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da Fabiorayden Guarda i messaggi
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()
Questa non è la soluzione migliore. Sarebbe preferibile usare l'evento onsubmit su <form>. Se i dati sono ok, si fa ritornare true per procedere con l'invio, altrimenti false per cancellare l'invio.

Quote:
Originariamente inviato da Fabiorayden Guarda i messaggi
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.
Avere una funzione più generica è possibile. Tra l'altro è anche possibile ottenere un array dei controlli contenuti in un form.
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%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 27-09-2007, 08:32   #4
Fabiorayden
Member
 
L'Avatar di Fabiorayden
 
Iscritto dal: Nov 2005
Città: Torino
Messaggi: 289
Quote:
Originariamente inviato da andbin Guarda i messaggi
Questa non è la soluzione migliore. Sarebbe preferibile usare l'evento onsubmit su <form>. Se i dati sono ok, si fa ritornare true per procedere con l'invio, altrimenti false per cancellare l'invio.

Avere una funzione più generica è possibile. Tra l'altro è anche possibile ottenere un array dei controlli contenuti in un form.
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ù.
La pagina dove c'è il form è strutturata così:

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>
Il terzo parametro che passo alla funzione ctrlForm vorrei che possa esser usato dalla funzione per validare il form, che sarebbe:

Codice:
function ctrlForm(val1,val2,nomeform)
{
    if(val1=="" || val2=="")
    {
       alert("Non hai inserito i dati");			
    }
    else
    {
       document.utente.submit();
    }
}
La funzione vale solo per il form chiamato utente, io cercavo un modo per poter passare nomeform al 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)
Fabiorayden è offline   Rispondi citando il messaggio o parte di esso
Old 27-09-2007, 08:36   #5
isAlreadyInUse
Senior Member
 
L'Avatar di isAlreadyInUse
 
Iscritto dal: Sep 2007
Messaggi: 754
Codice:
function submitForm(idForm){
    document.getelementById(idform).submit();
}
__________________
http://www.tevigroup.it/
isAlreadyInUse è offline   Rispondi citando il messaggio o parte di esso
Old 27-09-2007, 09:38   #6
Fabiorayden
Member
 
L'Avatar di Fabiorayden
 
Iscritto dal: Nov 2005
Città: Torino
Messaggi: 289
Quote:
Originariamente inviato da isAlreadyInUse Guarda i messaggi
Codice:
function submitForm(idForm){
    document.getelementById(idform).submit();
}
Su Internet Explorer il codice funziona, su Firefox no (anche scrivendo getElementById, che sarebbe il modo corretto).

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)
Fabiorayden è offline   Rispondi citando il messaggio o parte di esso
Old 27-09-2007, 09:47   #7
isAlreadyInUse
Senior Member
 
L'Avatar di isAlreadyInUse
 
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/
isAlreadyInUse è offline   Rispondi citando il messaggio o parte di esso
Old 27-09-2007, 10:01   #8
Fabiorayden
Member
 
L'Avatar di Fabiorayden
 
Iscritto dal: Nov 2005
Città: Torino
Messaggi: 289
Quote:
Originariamente inviato da isAlreadyInUse Guarda i messaggi
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>
Grazie per l'aiuto, ora la validazione del form funziona, forse il problema era nel modo in cui facevo il submit.
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)
Fabiorayden è offline   Rispondi citando il messaggio o parte di esso
Old 27-09-2007, 10:04   #9
isAlreadyInUse
Senior Member
 
L'Avatar di isAlreadyInUse
 
Iscritto dal: Sep 2007
Messaggi: 754
Evidentemente gli avrò messo paura
Buon lavoro
__________________
http://www.tevigroup.it/
isAlreadyInUse è offline   Rispondi citando il messaggio o parte di esso
Old 27-09-2007, 13:00   #10
andbin
Senior Member
 
L'Avatar di andbin
 
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>
Come si può vedere, è poi banalissimo applicare la validazione a più form.
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 27-09-2007, 13:32   #11
Fabiorayden
Member
 
L'Avatar di Fabiorayden
 
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();
    }
}
pagina html:
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>
Nel mio caso però all'aumentare dei campi di input da controllare dovrò ovviamente modificare la funzione.
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 13:34. Motivo: mancava del codice nella pagina html
Fabiorayden è offline   Rispondi citando il messaggio o parte di esso
Old 27-09-2007, 13:52   #12
andbin
Senior Member
 
L'Avatar di andbin
 
Iscritto dal: Nov 2005
Città: TO
Messaggi: 5206
Quote:
Originariamente inviato da Fabiorayden Guarda i messaggi
La tua funzione risulta molto più generica della mia, grazie.
Allora puoi usarla (e modificarla) come vuoi.

Quote:
Originariamente inviato da Fabiorayden Guarda i messaggi
Io, che avevo un file con le funzioni javascript e un altro file con il codice html, per adesso ho risolto così:
Sì ma dovresti far ritornare il true/false dalla funzione.
__________________
Andrea, SCJP 5 (91%) - SCWCD 5 (94%)
andbin è offline   Rispondi citando il messaggio o parte di esso
Old 27-09-2007, 17:00   #13
Fabiorayden
Member
 
L'Avatar di Fabiorayden
 
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)
Fabiorayden è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Marathon: arriva il Fortnite hardcore Marathon: arriva il Fortnite hardcore
HP Imagine 2026: abbiamo visto HP IQ all’opera, ecco cosa può (e non può) fare HP Imagine 2026: abbiamo visto HP IQ all’opera, ...
PNY RTX 5080 Slim OC, sembra una Founders Edition ma non lo è PNY RTX 5080 Slim OC, sembra una Founders Editio...
Wi-Fi 7 con il design di una vetta innevata: ecco il nuovo sistema mesh di Huawei Wi-Fi 7 con il design di una vetta innevata: ecc...
Core Ultra 7 270K Plus e Core Ultra 7 250K Plus: Intel cerca il riscatto ma ci riesce in parte Core Ultra 7 270K Plus e Core Ultra 7 250K Plus:...
BYD ha licenziato 100.000 persone nel 20...
FRITZ!Box 5690 Pro a 275€ e il nuovo FRI...
I segreti dei 2 nanometri di TSMC rubati...
CMF Buds 2 vs Nothing Ear (a): due auric...
Microonde e friggitrici ad aria con supe...
Amazon Haul: bestseller a -40% acquistan...
C'è ancora spazio per gli iMac: &...
GPU gaming a rischio? Micron oltre l'HBM...
iPhone 18 Pro, cambio di design in arriv...
OnePlus non molla: la serie Nord 6 sar&a...
GeForce RTX 3080 raffreddata con un diss...
Proofpoint mette in sicurezza gli agenti...
Annunci falsi su Bakeca con dati veri di...
Attenzione alla truffa dell'assegno di A...
Addio al mito delle batterie a stato sol...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 09:02.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2026, Jelsoft Enterprises Ltd.
Served by www3v