Björns studiewebb logotyp

Formulär i HTML

Innehåll

Formulär används för att hämta information från besökaren. På denna sida beskriv bl.a. hur formulär byggs upp, d.v.s. dess grundläggande struktur, hur innehållet i formulär skickas till webbservern och vilka element (kontroller) som kan finnas i ett formulär.

Observera att valet av ramverk för utseende av denna webbplats (Materialize) påverkar hur kontroller visas, vilket i vissa fall inte är så praktiskt!

Hur innehåll hämtas från formulär i servlets och skriptsidor (JSP och PHP) behandlas i mina underwebbar Java och PHP.

Att göra

2020-02-02

Beskriv taggen <label> samt lägg till den i alla exempel (för att få godkänt på tester i Lighthous i Google Chrome ;-)).

Placera kodexempel i taggen <code> för att göra dem tydligare.

Hur formulär byggs upp

Ett formulär består främst av tre delar

taggen <form>
Tagg som visar var formulär börjar och slutar samt där destination och HTML-metod (GET eller POST) att skicka formulär med.
kontroller (fält)
skapas med en eller flera av taggarna <input>, <textarea> och/eller <select>.
skicka knapp (submit)
Knapp för att skicka formulär.

Taggen <form>

Taggen <form> är, som nämnt ovan, den tagg som visar var formuläret börjar och slutar samt dess attribut används för att tala om var och hur formulärets innehåll ska skickas.

Attribut

De mest använda attributen är:

action
Var formulärets innehållet ska skickas, t.ex. /minsida.php eller https://kiltedviking.net/minsida.php.
method
Hur formulär ska skickas - med någon av HTTP-metoderna GET eller POST. (Mer om GET och POST finns i avsnitt nedan.)
Fler attribut
name
Friviliigt namn på formulär - användbart om flera formulär i sida eller om man önskar manipulera formulär med JavaScript.
<h1>Ett enkelt formul&auml;r</h1>
<form method="post" action="behandla.php">
  ...
</form>

Kontroller i formulär

I ett HTML-formulär kan finnas de flesta typer av (enkla) kontroller som kan finnas i ett program på dator. Exempel på några är textrutor (enkelradiga och flerradiga), listrutor, nedrullningsbara listrutor, kryssrutor, radioknappar och "vanliga" knappar. (Kontrollerna beskrivs längre ner på hemsidan.)

<label for="mintext">Fyll i namn:</label>
<input type="text" name="mintext"></p>

Skickaknapp (submit)

Skickaknappen är det som gör att formulärets innehåll skickas iväg när besökaren klickar på knappen och kan kompletteras med återställningsknapp (reset) för att tömma formulärets innehåll.

<input type="submit">
<input type="submit" value="Skicka">

Exempel på ett enkelt formulär

Exemplet nedan visa en textruta och en knapp med texten Skicka.

Öppna sida i webbläsare på dator för att visa exempel och studera dess bakomliggande kod.

Sätt på vilket formulär kan skickas

Formulär, eller snarare innehållet i formulärets kontroller, kan skickas på ett av två sätt: GET eller POST. Hur formuläret skickas anges genom att ange "get" eller "post" som värde till formulärets attribut method.

Metoden GET

Som standard så begär besökarens webbläsare hemsidor från webbservern m.h.a. metoden GET. Och om formulär sänds med metoden GET så kommer innehållet i formuläret att läggas till till URL:en, som formulärets attributet action pekar på, efter ett frågetecken. Om formuläret innehåller en textrutan med namnet "fornamn" och attributet action har värdet "behandla.asp" så skulle webbläsaren begära hemsidan med följande URL

behandla.asp?fornamn=varde_som_fyllts_i

Formulärets innehåll, eller snarare det efter frågetecknet, brukar kallas query string (benämnt som parametrar på hemsidan om länkar).

Fördelen med metoden GET är att man kan göra länkar med URL:er som innehåller en query string. T.ex. så finns det en Java servlet på Mälardalens högskolas webbserver som visar information om de anställda. Och på högskolans alla hemsidor finns (eller bör det finnas) en länk till informations- och teknikansvariga för hemsidorna. Länken till dessa har kod liknande följande:

<a href="http://www.mdh.se/se.mdh.Personal?
fornamn=Björn&efternamn=Persson">

Se hur (den resulterande) hemsidan ser ut. (Länken är gammal och jag jobbar inte längre för högskolan, men ni kan studera URL.)

Metoden POST

Om man istället ändrar metoden till POST så kommer innehållet i formuläret skickas som en del av kroppen på den begäran som webbläsaren gör till webbservern. D.v.s. vad som skickas är inte synligt för besökaren.

Denna metod är att föredra om innehållet i ett formulär innehåller ett lösenord eller mycket information. Det är dock ingen garanti att lösenordet inte blir avslöjat då lösenordet (oftast) ändå kommer skickas i klartext! Vad det gäller storleken på formulärets innehåll så finns det webbläsare och webbservrar som inte tillåter mer än en viss längd på URL:er. Om ett formulär skickar mycket data så är alltså POST det enda alternativet.

Metoden POST är även att föredra om en hemsida uppdaterar data i t.ex. en databas. Om besökaren skapar ett bokmärke/favorit till sidan så kommer bokmärket/favoriten inte att innehålla det som skickades med formuläret. Skälet till detta är att innehållet i formuläret skickades i kroppen på begäran som webbläsaren gjorde. Bokmärken/favoriter innehåller endast URL:en till hemsidan. Skaparen av servlet eller skriptsida kan då kontrollera om formulärets innehåll är tom och, om så är fallet, t.ex. skicka besökaren till formuläret.

Två exempel som visar skillnaden mellan metoderna GET och POST

Bägge formulär är de samma. Det som skiljer dem åt är värdet på attributet method i taggen <form> hur URL:en kommer se ut (se textfältet Address i Internet Explorer eller Location i Mozilla Firefox).

Öppna sida i webbläsare på dator för att visa exempel och studera dess bakomliggande kod.

Element i formulär

De flesta elementen (kontrollerna) i formulär skapas med taggen <input> och har inte en avslutande tagg. Det som avgör vilken typ av kontroll det ska vara är då attributet TYPE. För kontroller som bygger på taggen <input> har värdet på attributet type angivits i rubriken (t.ex. Enradig textruta - type="text").

De flerradiga textrutorna samt list- och kombinationsrutorna skapas med taggarna <textarea> respektive <select>. Den avslutande taggen är obligatorisk för bägge dessa taggar.

För varje kontroll visas först dess utseende sedan taggen, alla dess attribut samt exempelvärden för attributen. De attribut, utöver attributet type för taggen <input>, som är obligatoriska har markerats med texten [obl.] i förklaringen av attributen. (Attributen förklaras i ordningen: obligatoriska attribut först, attribut som bör användas därefter och sist de mindre frekvent använda attributen.)

Enradig textruta - type="text"

Utseende




HTML-kod

<input type="text" name="MinText" size="25"
  maxlength="25" value="Startvarde" />
<input type="text" name="MinText1" size="25"
  maxlength="25" placeholder="Startvarde" />

Förklaring till attributen

name
Kontrollens namn [obl.]. Detta namn bör vara unikt i formuläret.
size
Antal teckens bredd på kontrollen i tecken.
maxlength
Max antal tecken som besökaren tillåts fylla i.
placeholder
Text som kommer visas när fältet är tomt, men som tas bort när fältet fylls i (eller får fokus).
value
Text som kommer visas i kontrollen då hemsidan laddas.
Fler attribut
title
Beskrivning av elementets (fältets) betydelse - brukar visas när musmarkör vilar över element (fält).

Flerradig textruta

Denna kontroll är ett undantag från regeln då den har en avslutande tagg (som är obligatorisk). Eventuell text som skrivs mellan taggarna kommer vara synlig i textrutan då hemsidan laddas.

Utseende

HTML-kod

<textarea name="MinArea" rows="5" 
  cols="25">Startvarde</textarea>

Förklaring till attributen

name
Kontrollens namn [obl.]. Detta namn bör vara unikt om fler än en kontroll i formuläret.
rows
Höjden på kontrollen i antalet rader.
cols
Bredden på kontrollen i antal tecken.
Fler attribut
placeholder
Text som kommer visas när fältet är tomt, men som tas bort när fältet fylls i (eller får fokus).

Textruta för lösenord - type="password"

Observera att denna kontroll inte bör användas om formulärets metod är satt till GET. Lösenordet kommer då att skickas i klarttext som en del av URL:en!

Utseende

HTML-kod

<input type="password" name="MittLosenord"
 size="25" maxlength="25" value="Startvarde" />

Förklaring till attributen

name
Kontrollens namn [obl.]. Detta namn bör vara unikt om fler än en kontroll i formuläret.
size
Bredden på kontrollen i tecken.
maxlength
Antal tecken som besökaren tillåts fylla i.
value
Text som kommer visas i kontrollen då hemsidan laddas.

Dold textruta - type="hidden"

Du kanske frågar dig "Vad ska jag med en dold textruta då besökaren inte kan fylla i något i den?". Skälet till att man har dolda textrutor är för att man i dynamiska webbsidor t.ex. ska kunna mellanlagra innehållet från formulär som besökaren besökt tidigare.

Ett formulär bör inte vara för långt. Blir det för långt så bör man fundera på att bryta upp formuläret och placera det på flera webbsidor med kortare formulär (ett formulär som fylls i i flera steg). För att spara innehållet i tidigare ifyllda formulär, så att de kan användas i sista steget av formulärets ifyllande, brukar innehållet (från tidigare steg) placeras i textrutor som är dolda för besökaren.

Ett annat alternativ (till dolda textrutor) är att använda sessionsvariabler (finns i bl.a. JSP, PHP och servlets), med det är ett separat ämne i sig.

Utseende

(den är gömd så den syns inte :-)

HTML-kod

<input type="hidden" name="MinDold" 
  value="Startvarde" />

Förklaring till attributen

name
Kontrollens namn [obl.]. Detta namn bör vara unikt om fler än en kontroll i formuläret.
value
Text som kommer visas i kontrollen då hemsidan laddas.

Kryssruta - type="checkbox"

Avser något som bara kan anta två värden. Kryssrutor skiljer sig från kontrollerna ovan i att dess namn och värde skickas endast om kryssrutan är ifylld (förbockad).

Utseende

HTML-kod

<label for="MittKryss0">
  <input type="checkbox" id="MittKryss0"
    name="MittKryss0" value="Kryssad0" />
  MittKryss0
</label>

<label for="MittKryss1">
  <input type="checkbox" id="MittKryss1"
    name="MittKryss1" value="Kryssad1"
    checked="checked" />
  MittKryss1
</label>

För att kryssruta skulle fungera med CSS-ramverket jag valt för denna sida så var jag tvungen att lägga till id-attributet och en label-tagg.

Förklaring till attributen

name
Kontrollens namn [obl.]. Detta namn bör vara unikt om fler än en kontroll i formuläret.
value
Värde som ska skickas om kryssruta är ifylld. Om attributet inte används så skickas värdet "on".
checked
Om kryssruta ska vara ifylld eller inte när webbsida laddas. Detta attribut saknar värde (men ibland ser man att attribut har samma värde som dess namn, d.v.s. disabled="disabled").

Radioknapp - type="radio"

Radioknappar brukar kopplas samma (de ges samma värde på attributet name) vilket gör det möjligt att endast kunna markera en av dem (se exempel 5.3 nedan).

Utseende

HTML-kod

<label for="MinRadio">
  <input type="radio" id="MinRadio"
    name="MinRadio" value="Markerad0"
    checked="checked" />
  MinRadio0
</label>

Förklaring till attributen

name
Kontrollens namn [obl.]. Detta namn behöver inte vara unikt - men grupper av radioknappar måste vara (se exempel nedan).
value
Värde som ska skickas om radioknapp är markerad.
checked
Om radioknapp ska vara ifylld eller inte när webbsida laddas. Detta attribut saknar värde.

Använda radioknappar

I motsatts till kryssrutor så används radioknappar i grupper. För att skapa en grupp med radioknappar så ges radioknappar i gruppen samma värde på attributet name. Och för att avgöra vilken av radioknapparna (alternativen) som väljs används värdet på radioknapps value-attribut. Radioknappens betydelse visas lämpligen genom att text skrivs efter radioknappen, på så sätt kan radioknappar visas ovanför varandra (som i exempel nedan) oavsett längd på texterna.

Om vi vill att ett alternativ ska vara valt när formulär laddas så används attributet checked (utan värde) som i första gruppen. Men vi kan även låta inga av alternativen vara valda som i andra gruppen.

Grupp 1

Grupp 2

<form>
  <p>Grupp 1</p>

  <label for="a1">
    <input type="radio" id="a1" name="grupp1"
      value="1" checked="checked" />
    Alternativ 1
  </label>
  
  <label for="a2">
    <input type="radio" id="a2" name="grupp1"
      value="2" />
    Alternativ 2
  </label>
  
  <label for="a3">
    <input type="radio" id="a3" name="grupp1"
      value="3" />
    Alternativ 3
  </label>

  <p>Grupp 2</p>

  <label for="b1">
    <input type="radio" id="b1" name="grupp2"
      value="Ja" />
    Ja
  </label>
  
  <label for="b2">
    <input type="radio" id="b2" name="grupp2"
      value="Nej" />
    Nej
  </label>
</form>

Submit-knapp - type="submit"

En standardknapp som utlöser händelsen som skickar iväg formulärets innehåll till t.ex. CGI-program, servlet eller skriptsida för behandling.

Utseende


HTML-kod

<input type="submit" name="MinSubmit" />
<input type="submit" value="Skicka" 
  name="MinSubmit" />

Förklaring till attributen

value
Text som komer synas på knapp. Om detta attribut utelämnas kommer webbläsaren visa text i stil med "Skicka" (eller "Submit" om engelsk version av webbläsare).
name
Kontrollens namn. Detta namn bör vara unikt om fler än en kontroll i formuläret. Att ange namnet på en Submit-knapp kan vara användbart om man vill ha två Submit-knappar i samma formulär där de två knapparna ska utför olika saker. "Mottagande" servlet eller skriptsida kan kontrollera vilken knapp som klickats på för att avgöra vad som ska göras, t.ex. uppdatera eller lägga till.

Reset-knapp - type="reset"

Knapp som återställer formulär till det tillstånd det var när sida laddades.

Utseende


HTML-kod

<input type="reset" name="MinReset1" />
<input type="reset"
  value="&Aring;terst&auml;ll"
  name="MinReset2" />

Förklaring till attributen

value
Text som kommer synas på knapp. Om detta attribut utelämnas kommer webbläsaren visa text i stil med "Återställ" (eller "Reset" om engelsk version av webbläsare).
name
Kontrollens namn. Främst användbart i samband med JavaScript.

Kommandoknapp - type="button"

Har bl.a. (liksom de andra två knapptyperna ovan) en händelse Click som kan kopplas till t.ex. en funktion i JavaScript (se exempel 5.3 nedan, och JavaScript-webb, där knapp används för att stänga fönster).

Utseende

HTML-kod

<input type="button" value="Klicka mig!"
  name="MinKnapp" 
  onclick="javascript:alert('Du klickade')" />

Förklaring till attributen

value
Text som kommer synas på knapp.
name
Kontrollens namn.
onclick
(händelse-)attribut där (JavaScript-)logik kan kopplas.

Listrutor

Listrutor har en egen tagg - <select> - och kan vara nedrullningsbara (eng. drop-down list) eller inte. Det som styr om en listruta är nedrullningsbar eller inte är attributet size eller avsaknaden av attributet (standard idag är 1). Om size är 1 (eller utelämnas) så visas listruta nedrullningsbar och om size är större än 1 som en vanlig listruta med lika många rader som värdet på size. Listrutor namnges, liksom övriga kontroller, med attributet name i select- taggen.

De olika alternativen i listrutor markeras med taggen <option> inom select-taggen. Om antalet alternativ är fler än antalet rader som kan visas så kommer automatiskt en rullningslist att visas.

Nedrullningsbar listruta

En nedrullningsbar listruta visar eventuellt valt alternativ och en knapp för att "rulla ner" lista med alternativ.

Utseende

HTML-kod

<select size="1" name="MinListruta">
  <option>Alternativ 1</option>
  <option>Alternativ 2</option>
  <option>Alternativ 3</option>
  <option>Alternativ 4</option>
    ...
</select>

Listruta med flera rader

Listor brukar som standard visas med 8 synliga alternativ.

Utseende

HTML-kod

<select size="5" name="MinListruta"
  multiple="multiple">
    <option>Alternativ 1</option>
    <option>Alternativ 2</option>
    <option>Alternativ 3</option>
    <option>Alternativ 4</option>
      ...
</select>

Listrutor tillåter även att man kan välja flera alternativ (genom att hålla ner CTRL-tangent och klicka). För att göra detta möjligt använder vi attributet multiple (utan värde!) i select-taggen. (Prova gärna i listrutan ovan.) Attributet multiple kan endast användas med icke-nedrullningsbara listrutor och användandet av attributet kommer automatiskt att konvertera taggen till en "vanlig" listruta (oavsett om size sätts till 1).

Styra vilket värde som skickas

Om vi inte anger ett värde som ska skickas så kommer texten (innehållet) i option-taggen att skickas. Men ibland kan det vara mer praktiskt att skicka t.ex. ett tal (som t.ex. motsvarar en primärnyckel i en tabell) istället för en lång text. För att skicka ett annat värde, än det i option-taggen, använder vi attributet value i option-taggen. I exemplet nedan kommer t.ex. värdet "1" skickas istället för texten "Alternativ 1".

<select size="5" name="MinLista">
  <option value="1">Alternativ 1</option>
  <option value="2">Alternativ 2</option>
    ...
</select>

Observera att även om vi skriver ett tal så kommer värdet "1" att skickas som en sträng! Alla värden i formulär skickas nämligen som strängar och som vi måste konvertera till respektive datatyp (om det behövs) i hemsidan/programmet som tar emot formulärets innehåll.

Markera ett alternativ som standard

Vi kan även låta ett av alternativen vara markerade som standard då hemsidan laddas (eller laddas om). För detta använder vi attributet selected (utan värde!) i den option-tagg som motsvarar det värde vi vill ha markerad. Nedrullningsbara listrutor kommer oftast att ha första alternativet i listan markerat som standard om man inte använder attributet selected. Följande kod


<select size="1" name="MinKombo">
  <option>Alternativ 1</option>
  <option 
    selected="selected">Alt. 2</option>
  <option>Alternativ 3</option>
  <option>Alternativ 4</option>
    ...
</select>

Ett större exempel på formulär

Nästa exempel är ett större formulär med textrutor (en och flera rader), sammankopplade radioknappar, kryssrutor och knappar för att skicka samt tömma formulär. För att se koden: titta på hemsidan och välj "Visa källa" (eller motsvarande i webbläsaren). Kräver en webbserver med stöd för ASP!

Öppna sida i webbläsare på dator för att visa exempel och studera dess bakomliggande kod.