Form, in informatica, il termine (letteralmente formulario, modulo)[1] indica la parte di interfaccia utente di un'applicazione web che consente all'utente client di inserire e inviare al web server/application server uno o più dati liberamente digitati dallo stesso sulla tastiera attraverso l'uso di componenti grafici detti widget presenti sull'interfaccia stessa; per descriverlo può essere utile la metafora della "scheda da compilare" per l'inserimento di dati. Nella maggior parte dei casi il termine è riferito a form contenuti in una pagina web: ad esempio, le caselle di testo e i menù a tendina di una pagina di registrazione o di login costituiscono un form.
Descrizione
Più in particolare, l'elemento HTML <FORM> è usato per realizzare form in una pagina web. In HTML sono considerati parte del form anche i pulsanti ripristina o cancella e invia. Di solito i form vengono utilizzati per inviare dati ad un database server oppure per inviare e-mail.
Il termine è usato, in senso più esteso, nell'ambiente di sviluppo Visual Basic per indicare una finestra principale dell'applicazione, in cui possono essere inseriti elementi visuali come pulsanti o caselle di testo.
Crea un modulo dove all'interno possono essere contenuti (annidati) uno o più elementi sottoelencati.
<method=post action="url">
L'attributo method specifica con il suo valore che i dati saranno inviati al server col metodo Post dell'HTTP puntando, tramite l'attributo action, alla rispettiva pagina di elaborazione di URL specificato; questo elemento è tipicamente sempre presente.
Crea una casella di testo a linea singola. L'attributo Name con il suo valore assegnato identifica il nome della variabile passata alla parte di elaborazione, mentre l'attributo Value con il valore assegnato popola il campo con un valore assegnato; l'attributo opzionale Size imposta con il suo valore la lunghezza della casella, mentre l'attributo opzionale Maxlength imposta con il suo valore il numero massimo di caratteri inseribili (può essere più grande di Size);
<input type="file" name="nome">
Crea casella per il file upload ovvero il caricamento del file sul browser del client per l'invio al server; l'attributo Name con il suo valore assegnato identifica il nome della variabile passata alla parte di elaborazione;
<input type="password">
Crea una casella di testo a linea singola per l'inserimento di una password con valori digitati/visualizzati oscurati per preservarne la confidenzialità;
<textarea>...</textarea>
Crea un'area di testo multilinea impostasta dagli attributi cols (colonne) e rows (righe). Il testo tra i tag apparirà nell'area di testo al caricamento della pagina.
<select name="foo">...</select>
Crea un menù ad elenco dal quale l'utente può scegliere una sola voce. Può essere visualizzato come un menù a cascata.
<option>...</option>
Crea una voce all'interno del menù.
<input type="radio">
Crea una casella di scelta singola di tipo radio button.
<input type="checkbox">
Crea una casella di spunta per controllare il contenuto dell'input(checkbox).
<input type="radio">
Crea un pulsante radio; se più pulsanti radio hanno lo stesso nome, l'utente potrà selezionarne solo uno.
L'elemento <input> ha nuovi valori per l'attributo type.
search: un campo di ricerca.
tel: controllo per la modifica di un numero telefonico. È possibile utilizzare gli attributi pattern e maxlength per limitare i valori immessi dall'utente.
email: controllo per la modifica di un indirizzo email.
Nuovi attributi di <input>
list: l'ID di un elemento <datalist> il cui contenuto, che consiste in elementi <option>, dovrà essere utilizzato come suggerimento.
pattern: Un'espressione regolare usata negli <input> di tipo text, tel, search, url, ed email.
form: Una stringa che indica a quale elemento <form> è figlio l'input.
formmethod: Una stringa che indica il metodo HTTP (GET o POST) da usare per l'invio dei dati al server.
x-m-errormessage: Contiene un messaggio quando il campo non supera la validazione (solo per Firefox).
Elemento <form>:
novalidate: Questo nuovo attributo fa in modo che il form non richieda la validazione all'utente.
Elemento <datalist>
<datalist> racchiude una lista di elementi <option> da suggerire all'utente durante la compilazione di un <input>.
Elemento <output>
<output> rappresenta il risultato di un calcolo. Si usa l'attributo for per specificare una relazione tra un elemento <output> e altri elementi del documento (input o parametri).
Attributo <placeholder>
<placeholder> si applica agli elementi <input> e <textarea>, fornendo all'utente un suggerimento su cosa dovrebbe immettere nel campo.
Attributo <autofocus>
<autofocus> evidenzia un campo. Può essere assegnato ad un solo campo per ciascun form. Si applica agli elementi <input>, <button>, <select> e <textarea>.
Vincoli di validazione
L'attributo required nell'elemento <input>, <select> e <textarea> indica che il campo deve essere compilato.
L'attributo pattern nell'elemento <input> stabilisce il valore in modo che corrisponda una specifica cifra.
Gli attributi min e max nell'elemento <input> specifica il valore minimo e massimo che può essere immesso.
L'attributo step nell'elemento <input> vincola i valori che possono essere immessi.
L'attributo maxlength negli elementi <input> e <textarea> stabilisce il numero massimo di caratteri che l'utente può immettere.
I valori url e email nell'attributo type restringono i valori accettati rispettivamente ad un URL o ad un indirizzo e-mail valido.
Altri utilizzi
Al di là degli specifici impieghi descritti sopra, in informatica (in generale: nelle informazioni digitilizzate) per form s'intende una maschera (o modulo) ovvero un'area, solitamente strutturata in righe e colonne (i cui bordi o sfondi possono anche essere non visibili) e con dei campi che fungono da etichette descrittive, nella quale occorre inserire informazioni (dati, valori, comandi, espressioni, ecc) da parte dell'utilizzatore della relativa applicazione software. Le informazioni possono anche essere già precompilate e quindi l'utente deve scegliere (per ciascuna cella o riquadro) il valore preferito (menù a tendina, elenco selezionabile, bottone, ecc).
Per essere precisi il form è il modulo non compilato: quando è compilato allora diventa l'informazione documentata output (una prenotazione, un ordine, una valutazione, un questionario, una dichiarazione, ecc).
Formattazione
I form vengono formattati attraverso i CSS che permettono di dare un aspetto professionale e accattivante ai moduli rispetto all' HTML puro[3][4]. Esempio:
Il sociallogin è una forma di single sign-on che utilizza le informazioni esistenti di un servizio di social network come Facebook, Twitter o Google, per accedere a un sito web di terze parti[5] invece di creare un nuovo account di accesso specifico per quel sito web. È progettato per semplificare gli accessi per gli utenti finali e per fornire informazioni demografiche sempre più affidabili agli sviluppatori web[6].
Vantaggi
Gli studi hanno dimostrato che i moduli di registrazione del sito Web sono inefficienti in quanto molte persone forniscono dati falsi, dimenticano le informazioni di accesso al sito o semplicemente rifiutano di registrarsi in primo luogo. Uno studio condotto nel 2011 da Janrain e Blue Research ha rilevato che il 77% dei consumatori preferiva l'accesso social come mezzo di autenticazione rispetto ai metodi di registrazione online più tradizionali[7]. Ulteriori vantaggi sono:
Contenuto mirato: i siti Web possono ottenere un profilo e dati del grafico sociale per indirizzare contenuti personalizzati all'utente.
Identità multiple: gli utenti possono accedere a siti Web con più identità sociali, consentendo loro di controllare meglio la propria identità online.
Dati di registrazione: molti siti Web utilizzano i dati del profilo restituiti dall'accesso social invece di consentire agli utenti di inserire manualmente le proprie informazioni di identificazione personale)nei moduli. Questo accelera la registrazione o il processo di iscrizione.
Email pre-convalidata: impedisce all'utente di fornire un indirizzo e-mail inventato durante il processo di registrazione.
Collegamento dell'account: molti siti Web consentono agli utenti precedenti di collegare l'account del sito preesistente al proprio account di accesso social senza forzare la nuova registrazione.
Rischi
Il rischio principale legato all'uso dei form è il furto dei propri dati mentre lo si compila[8][9]. Inoltre gli accessi sociali sono spesso implementati in modo insicuro. Gli utenti, in questo caso, devono fidarsi di ogni applicazione che ha implementato questa funzione per gestire il proprio identificatore in modo confidenziale[10].
Inoltre, facendo affidamento su un account utilizzabile su molti siti Web, l'accesso social crea un unico punto di errore, aumentando così notevolmente il danno che sarebbe causato se l'account venisse violato[11].
Con l'acronimo inglese CAPTCHA si denota nell'ambito dell'informatica un test fatto di una o più domande e risposte per determinare se l'utente sia un umano e non un computer o, più precisamente, un bot.
<formid="send-comment"aria-label="Add a comment"><labelfor="username">Username</label><inputid="username"name="username"autocomplete="nickname"autocorrect="off"type="text"><labelfor="email">Email</label><inputid="email"name="email"autocomplete="email"autocapitalize="off"autocorrect="off"spellcheck="false"type="text"><labelfor="comment">Comment</label><textareaid="comment"name="comment"></textarea><inputvalue="Comment"type="submit"></form>