Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI
Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI
Con velocità teoriche fino a 11 Gbps, gestione tramite app intelligente e protezione avanzata dei dispositivi, Roamii BE Pro porta il Wi‑Fi 7 tri‑band nelle abitazioni più esigenti. Un sistema Wi-Fi Mesh proposto da MSI allo scopo di garantire agli utenti una rete fluida e continua capace di sostenere streaming 8K, gaming competitivo e le applicazioni moderne più esigenti in termini di banda
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi
Mate X7 rinnova la sfida nel segmento dei pieghevoli premium puntando su un design ancora più sottile e resistente, unito al ritorno dei processori proprietari della serie Kirin. L'assenza dei servizi Google e del 5G pesa ancora sull'esperienza utente, ma il comparto fotografico e la qualità costruttiva cercano di compensare queste mancanze strutturali con soluzioni ingegneristiche di altissimo livello
Nioh 3: souls-like punitivo e Action RPG
Nioh 3: souls-like punitivo e Action RPG
Nioh 3 aggiorna la formula Team NINJA con aree esplorabili più grandi, due stili di combattimento intercambiabili al volo (Samurai e Ninja) e un sistema di progressione pieno di attività, basi nemiche e sfide legate al Crogiolo. La recensione entra nel dettaglio su combattimento, build, progressione e requisiti PC
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


Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo MSI Sistema Mesh Roamii BE Pro: il Wi-Fi 7 secondo M...
Recensione HUAWEI Mate X7: un foldable ottimo, ma restano i soliti problemi Recensione HUAWEI Mate X7: un foldable ottimo, m...
Nioh 3: souls-like punitivo e Action RPG Nioh 3: souls-like punitivo e Action RPG
Test in super anteprima di Navimow i220 LiDAR: il robot tagliaerba per tutti Test in super anteprima di Navimow i220 LiDAR: i...
Dark Perk Ergo e Sym provati tra wireless, software via browser e peso ridotto Dark Perk Ergo e Sym provati tra wireless, softw...
EPOS H3 Hybrid a soli 39€: cuffie gaming...
Samsung rilancia l'assistenza: ora puoi ...
Facebook si rinnova: nuove funzioni AI p...
Da 139€ a 198€, quale scegliere fra Lefa...
Microsoft aggiorna Windows 10: in distri...
Windows 11 si aggiorna: le novità del Pa...
ECOVACS DEEBOT MINI di nuovo a meno di 2...
La Russia rallenta Telegram: nuove restr...
Nuovi standard di sicurezza per l'avvio ...
Mini-LED 34'' WQHD (3440x1440) a prezzo ...
Zero LS1 debutta in Italia: lo scooter e...
Cina, sviluppata batteria al litio semi-...
Intel TDX 1.5: 5 vulnerabilità ri...
In super sconto, con 100€ di differenza:...
Maxi TV da 75'' sotto i 600€: Hisense a ...
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: 10:53.


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