Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Qrevo Curv 2 Flow è l'ultima novità di casa Roborock per la pulizia di casa: un robot completo, forte di un sistema di lavaggio dei pavimenti basato su rullo che si estende a seguire il profilo delle pareti abbinato ad un potente motore di aspirazione con doppia spazzola laterale
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Abbiamo guidato per diversi giorni la Alpine A290, la prima elettrica del nuovo corso della marca. Non è solo una Renault 5 sotto steroidi, ha una sua identità e vuole farsi guidare
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Abbiamo provato a fondo il nuovo Magic 8 Lite di HONOR, e per farlo siamo volati fino a Marrakech , dove abbiamo testato la resistenza di questo smartphone in ogni condizione possibile ed immaginabile. Il risultato? Uno smartphone praticamente indistruttibile e con un'autonomia davvero ottima. Ma c'è molto altro da sapere su Magic 8 Lite, ve lo raccontiamo in questa recensione completa.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 26-09-2007, 18: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, 19: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, 21: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, 09: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, 09: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, 10: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, 10: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, 11: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, 11: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, 14: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, 14: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 14:34. Motivo: mancava del codice nella pagina html
Fabiorayden è offline   Rispondi citando il messaggio o parte di esso
Old 27-09-2007, 14: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, 18: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


Roborock Qrevo Curv 2 Flow: ora lava con un rullo Roborock Qrevo Curv 2 Flow: ora lava con un rull...
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite Alpine A290 alla prova: un'auto bella che ti fa ...
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile Recensione HONOR Magic 8 Lite: lo smartphone ind...
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora Sony WF-1000X M6: le cuffie in-ear di riferiment...
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI Snowflake porta l'IA dove sono i dati, anche gra...
AOC propone un QD-OLED al prezzo di un I...
AGCOM segnalerà la AI Mode di Goo...
L'Estonia porta ChatGPT in classe: firma...
2 nm giapponesi contro TSMC: il piano di...
Questa scopa elettrica Tineco iFLOOR 5 è...
FRITZ!Box 6825 4G sbarca in Italia a 129...
Red Hat presenta Digital Sovereignty Rea...
AMD Zen 6 'Olympic Ridge': sette configu...
Amazon batte Walmart dopo 30 anni: il so...
Digos nel mirino dell'intelligence cines...
Sony non vuole aumentare il prezzo della...
Energia geotermica: la (costosa) rispost...
MG ha già venduto 1 milione di au...
"Something Big Is Happening" —...
Renault chiude il 2025 con una perdita r...
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: 23:46.


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