aboutsummaryrefslogtreecommitdiff
path: root/files/nl/learn/forms/your_first_form/index.html
diff options
context:
space:
mode:
Diffstat (limited to 'files/nl/learn/forms/your_first_form/index.html')
-rw-r--r--files/nl/learn/forms/your_first_form/index.html274
1 files changed, 0 insertions, 274 deletions
diff --git a/files/nl/learn/forms/your_first_form/index.html b/files/nl/learn/forms/your_first_form/index.html
deleted file mode 100644
index 0d9705f88e..0000000000
--- a/files/nl/learn/forms/your_first_form/index.html
+++ /dev/null
@@ -1,274 +0,0 @@
----
-title: My first HTML form
-slug: Learn/Forms/Your_first_form
-tags:
- - CSS
- - Formulier
- - HTML
- - voorbeeld
-translation_of: Learn/Forms/Your_first_form
-original_slug: Learn/HTML/Forms/Your_first_HTML_form
----
-<p>Dit is een inleidend artikel tot HTML formulieren.  Door middel van een eenvoudig contactformulier maken we kennis met de basiselementen van HTML formulieren. Dit artikel veronderstelt dat de lezer niets afweet van HTML formulieren, maar dat hij een basiskennis heeft van <a href="/en-US/docs/Web/Guide/HTML/Forms_in_HTML">the basics of HTML</a> en <a href="/en-US/docs/Learn/Getting_started_with_the_web/CSS_basics">CSS</a>.</p>
-
-<h2 id="Voordat_we_beginnen">Voordat we beginnen</h2>
-
-<h3 id="Wat_is_een_HTML_formulier">Wat is een HTML formulier?</h3>
-
-<p>HTML formulieren zijn de belangrijkste schakel tussen een gebruiker en een website of een applicatie. Zij laten gebruikers toe gegevens naar websites te sturen. Meestal zal dat naar de server zijn maar een webpagina kan de gegevens ook zelf interpreteren.</p>
-
-<p>Een HTML formulier bestaat uit een aantal elementen. Bijvoorbeeld tekstvelden (bestaande uit één of meerdere regels), keuzelijsten, knoppen of radioknoppen. Meestal zullen deze elementen voorzien zijn van een label dat de funktie van het element aangeeft.</p>
-
-<h3 id="Wat_is_er_nodig_om_met_formulieren_te_werken">Wat is er nodig om met formulieren te werken?</h3>
-
-<p>Een  editor (<a href="/en-US/docs/">Sublime</a> of <a href="/en-US/docs/">Atom</a> zijn goede voorbeelden) en een webbrowser. Natuurlijk zijn er volwaardige IDE's zoals <a href="/en-US/docs/Mozilla/Tech/XUL/Using_Visual_Studio_as_your_XUL_IDE">Visual Studio</a>, <a href="/en-US/docs/Mozilla/Developer_guide/Eclipse">Eclipse</a>, <a href="http://www.aptana.com/" rel="external" title="http://www.aptana.com/">Aptana</a> en andere.</p>
-
-<p>Het verschil tussen een HTML formulier en een gewoon HTML document is dat de gegevens die door het formulier verzameld worden naar een webserver moeten gestuurd worden. Dus er moet een server voorzien worden om de gegevens te ontvangen en te verwerken. Hoe een server moet opgezet worden is buiten het bestek van dit artikel maar kan gevonden worden in het artike <a href="https://developer.mozilla.org/en-US/docs/HTML/Forms/Sending_and_Retrieving_form_data" title="/en-US/docs/HTML/Forms/Sending_and_retrieving_form_data">Sending and retrieving form data</a>.</p>
-
-<h2 id="Ontwerp_van_het_formulier">Ontwerp van het formulier</h2>
-
-<p>Alvorens te beginnen met schrijven moet eerst  het formulier ontworpen worden.  Dit laat toe vast te leggen welke gegevens er van de gebruiker gevraagd worden. Een te druk formulier kan al vlug aversie opwekken bij de gebruiker. Dus hou het simpel: vraag alleen wat absoluut nodig is. Het formulierontwerp is een zeer belangrijke stap in de opbouw van een site of een applicatie.  Het is buiten het bestek van dit artikel om in te gaan op gebruiksvriendelijk formulierontwerp maar volgende publicaties kunnen daarbij nuttig zijn:</p>
-
-<ul>
- <li>Smashing Magazine : <a href="https://www.smashingmagazine.com/2011/11/extensive-guide-web-form-usability/">an extensive guide web to form usability.</a></li>
- <li>UXmatters betreffende<a href="http://www.uxmatters.com/mt/archives/2012/05/7-basic-best-practices-for-buttons.php" rel="external" title="http://www.uxmatters.com/mt/archives/2012/05/7-basic-best-practices-for-buttons.php">basic best practices</a> voor complexe formulieren, zoals  <a href="http://www.uxmatters.com/mt/archives/2012/05/7-basic-best-practices-for-buttons.php" rel="external" title="http://www.uxmatters.com/mt/archives/2012/05/7-basic-best-practices-for-buttons.php"> </a> <a href="http://www.uxmatters.com/mt/archives/2010/03/pagination-in-web-forms-evaluating-the-effectiveness-of-web-forms.php" title="http://www.uxmatters.com/mt/archives/2010/03/pagination-in-web-forms-evaluating-the-effectiveness-of-web-forms.php">multi-page forms</a>.</li>
-</ul>
-
-<p>In dit artikel bouwen we een eenvoudig contactformulier. We beginnen met een ruwe schets.</p>
-
-<p><img alt="The form to build, roughly sketch" src="/files/4579/form-sketch-low.jpg" style="border-style: solid; border-width: 1px; height: 352px; width: 400px;"></p>
-
-<p>Het formulier bevat drie tekstvelden en een knop. De gebruiker wordt gevraagd naar de naam, het e-mailadres en het bericht dat hij wil verzenden. Bij een druk op de knop wordt het bericht verzonden naar de server.</p>
-
-<h2 id="Maak_uw_handen_vuil_aan_HTML">Maak uw handen vuil aan HTML</h2>
-
-<p>Nu zijn we klaar om aan het formulier te beginnen. Om het contactformulier op te maken hebben we de volgende HTML elementen nodig: {{HTMLelement("form")}}, {{HTMLelement("label")}}, {{HTMLelement("input")}}, {{HTMLelement("textarea")}}, en {{HTMLelement("button")}}.</p>
-
-<h3 id="Het_HTMLelement(form)_element">Het {{HTMLelement("form")}} element</h3>
-
-<p>Alle HTML formulieren beginnen met een {{HTMLelement("form")}} element als volgt:</p>
-
-<pre class="brush:html;">&lt;form action="/my-handling-form-page" method="post"&gt;
-
-&lt;/form&gt;</pre>
-
-<p>Dit element definiëert een formulier. Het is een container element als {{HTMLelement("div")}} of {{HTMLelement("p")}} maar het bevat ook een aantal attributen die aangeven hoe het formulier zich gedraagt. Alle attributen zijn optioneel maar in de praktijk wordt het aangeraden van steeds minstens het <code>action</code> attribuut en het <code>methode</code> attribuut te gebruiken.</p>
-
-<ul>
- <li>Het <code>action</code> attribuut bepaalt de locatie (URL) waar de gegevens van het formulier naar toe gezonden worden.</li>
- <li>Het <code>methode</code> attribuut bepaalt met welke HTTP methode de gegevens worden verzonden (dit kan zijn "get" of "post").</li>
-</ul>
-
-<p>Zie het artikel <a href="https://developer.mozilla.org/en-US/docs/HTML/Forms/Sending_and_retrieving_form_data" title="/en-US/docs/HTML/Forms/Sending_and_retrieving_form_data">Sending and retrieving form data</a> voor getaileerde informatie over hoe attributen werken.</p>
-
-<h3 id="Widgets_toevoegen_met_de_HTMLelement(label)_HTMLelement(input)_en_HTMLelement(textarea)_elementen">Widgets toevoegen met de {{HTMLelement("label")}}, {{HTMLelement("input")}} en {{HTMLelement("textarea")}} elementen</h3>
-
-<p>Het contactformulier is vrij eenvoudig en bevat drie tekstvelden, elk met een label. Het veld voor de naam is een eenvoudig tekstveld met één regel. Het veld voor het e-mailadres is ook een tekstveld met één regel maar dat alleen een e-mailadres aanvaardt. Het tekstveld voor het bericht is een eenvoudig tekstveld met meerdere regels.</p>
-
-<p>In HTML taal ziet de code er aldus uit:</p>
-
-<pre class="brush:html;">&lt;form action="/my-handling-form-page" method="post"&gt;
- &lt;div&gt;
- &lt;label for="name"&gt;Name:&lt;/label&gt;
- &lt;input type="text" id="name" name="user_name" /&gt;
- &lt;/div&gt;
- &lt;div&gt;
- &lt;label for="mail"&gt;E-mail:&lt;/label&gt;
- &lt;input type="email" id="mail" name="user_mail" /&gt;
- &lt;/div&gt;
- &lt;div&gt;
- &lt;label for="msg"&gt;Message:&lt;/label&gt;
- &lt;textarea id="msg" name="user_message"&gt;&lt;/textarea&gt;
- &lt;/div&gt;
-&lt;/form&gt;</pre>
-
-<p>De {{HTMLelement("div")}} elementen dienen om de code eenvoudig te structureren en om de stijl gemakkelijk aan te passen (zie verder). Let op het gebruik van het <em>for </em>attribuut<em> </em>in alle {{HTMLelement("label")}} elementen. Dit is een formele manier om een label aan een formulier te linken. Dit attribuut verwijst naar de<em> id </em>van de overeenkomstige widget. Dit wordt onder andere gedaan opdat de gebruiker op het label kan klikken om de widget te activeren. Andere redenen zijn beschreven in het artikel: <a href="/en-US/docs/HTML/Forms/How_to_structure_an_HTML_form" title="/en-US/docs/HTML/Forms/How_to_structure_an_HTML_form">How to structure an HTML form</a>.</p>
-
-<p>Voor het {{HTMLelement("input")}} element is het belangrijkste attribuut het <code>type</code> attribuut. Dit attribuut bepaalt hoe het {{HTMLelement("input")}} element zich gedraagt. Dit verdient de nodig aandacht omdat de gevolgen ingrijpend kunnen zijn. Het artikel <a href="/en-US/docs/HTML/Forms/The_native_form_widgets" rel="external" title="/en-US/docs/HTML/Forms/The_native_forms_widgets">native form widgets</a> geeft meer details hierover. In het voorbeeld wordt de waarde <code>text </code>gebruikt omdat dit de defaultwaarde is voor dit attribuut. Zo accepteert het tekstveld elke tekst zonder verdere controle of validatie. Met de waarde <code>email</code> wordt een tekstveld gedefiniëerd dat alleen een juist gevormd e-mailadres aanvaardt. Dus met dit laatste wordt het tekstveld omgevormd tot een soort intelligent veld dat enkele controles uitvoert op de gegevens die de gebruiker ingeeft. Meer details over validatie van formulieren is te vinden in het artikel <a href="/en-US/docs/HTML/Forms/Data_form_validation" title="/en-US/docs/HTML/Forms/Data_form_validation">Form data validation</a>.</p>
-
-<p>Tenslotte iets over de syntax  <code>&lt;input /&gt;</code> vs. <code>&lt;textarea&gt;&lt;/textarea&gt;</code>. Dit is een van de eigenaardigheden van HTML. Het element <code>&lt;input&gt;</code> is een element dat zichzelf afsluit. Dit wil zeggen dat, indien de gebruiker het element formeel wil sluiten, hijzelf "<em>/</em>"  moet toevoegen op het einde van het element. {{HTMLElement("textarea")}} daarentegen is geen element dat zichzelf afsluit zodat de gebruiker zelf moet zorgen voor de juiste afsluiting.  Dit heeft invloed op een specifieke eigenschap van HTML formulieren: de manier waarop de defaultwaarde wordt bepaald. Om de defaultwaarde van een {{HTMLElement("input")}} element te bepalen moet het  <code>value</code> attribuut als volgt gebruikt worden:</p>
-
-<pre class="brush:html;">&lt;input type="text" value="by default this element is filled with this text" /&gt;</pre>
-
-<p>Om daarentegen de defaultwaarde  van een {{HTMLElement("textarea")}} element op te geven moet deze waarde tussen begin- en eindtag van het {{HTMLElement("textarea")}} element opgegeven worden:</p>
-
-<pre class="brush:html;">&lt;textarea&gt;by default this element is filled with this text&lt;/textarea&gt;</pre>
-
-<h3 id="En_tenslotte_om_te_eindigen_een_HTMLelement(button)">En tenslotte om te eindigen een {{HTMLelement("button")}}</h3>
-
-<p>Er moet alleen nog een knop toevoegd worden om de gebruiker toe te laten zijn bericht te verzenden zodra het formulier ingevuld is. Dit gebeurt met het {{HTMLelement("button")}} element:</p>
-
-<pre class="brush:html;">&lt;form action="/my-handling-form-page" method="post"&gt;
- &lt;div&gt;
- &lt;label for="name"&gt;Name:&lt;/label&gt;
- &lt;input type="text" id="name" name="user_name" /&gt;
- &lt;/div&gt;
- &lt;div&gt;
- &lt;label for="mail"&gt;E-mail:&lt;/label&gt;
- &lt;input type="email" id="mail" name="user_mail" /&gt;
- &lt;/div&gt;
- &lt;div&gt;
- &lt;label for="msg"&gt;Message:&lt;/label&gt;
- &lt;textarea id="msg" name="user_message"&gt;&lt;/textarea&gt;
- &lt;/div&gt;
-
- &lt;div class="button"&gt;
- &lt;button type="submit"&gt;Send your message&lt;/button&gt;
- &lt;/div&gt;
-&lt;/form&gt;</pre>
-
-<p>Er zijn drie types van knoppen: <code>submit</code>, <code>reset</code>, en <code>button</code>.</p>
-
-<ul>
- <li><code>submit</code> zendt de gegevens naar de webpagina die bepaalt wordt door het <code>action</code> attribuut van het {{HTMLelement("form")}} element.</li>
- <li>De <code>reset</code> knop resets alle widges naar hun defaultwaarden. Vanuit het  het UX standpuntwordt dit niet aangeraden.</li>
- <li>Klikken op een <code>button</code> knop doet in eerste instantie niets maar dat is verbazend nuttig omdat met JavaScript de gebruiker deze toets elke funktie kan geven.</li>
-</ul>
-
-<p>Met het {{HTMLElement("input")}} element en met het corresponderende  type kan ook een knop gegenereerd worden. Het grote verschil met het {{HTMLelement("button")}} element is dat het {{HTMLelement("input")}} element slechts gewone tekst als label toestaat terwijl het {{HTMLelement("button")}} element volledige HTML inhoud accepteert als label.</p>
-
-<h2 id="De_zaken_mooier_maken_met_CSS">De zaken mooier maken met CSS</h2>
-
-<p>Nu het HTML formuler klaar is kan het bekeken worden in een browser. Maar het ziet er niet erg netjes uit.</p>
-
-<p><img alt="" src="/files/4049/form-no-style.png" style="height: 170px; width: 534px;"></p>
-
-<p>Met een CSS stylesheet kan het wat netter gemaakt worden.</p>
-
-<p>Om te beginnen het formulier zelf. Het kan gecentreerd worden en er kan een boord rond getrokken worden:</p>
-
-<pre class="brush:css;">form {
- /* Just to center the form on the page */
- margin: 0 auto;
- width: 400px;
- /* To see the outline of the form */
- padding: 1em;
- border: 1px solid #CCC;
- border-radius: 1em;
-}</pre>
-
-<p>Dan kan er wat ruimte ingevoegd worden tussen de widgets:</p>
-
-<pre class="brush:css;">form div + div {
- margin-top: 1em;
-}</pre>
-
-<p>Om een formulier leesbaar te maken is het aangeraden om alle labels dezelfde grootte te geven en ze uit te lijnen aan dezelfde zijde. Hier zullen we ze rechts uitlijnen. Maar soms is links uitlijnen ook goed.</p>
-
-<pre class="brush:css;">label {
- /* To make sure that all labels have the same size and are properly aligned */
- display: inline-block;
- width: 90px;
- text-align: right;
-}</pre>
-
-<p>Het moeilijkste met HTML formulieren is de styling van de HTML widgets zelf. Tekstvelden zijn nog gemakkelijk te stylen maar bij andere widgets is dat niet zo. Meer over stylen van HTML widgets is te vinden in <a href="/en-US/docs/HTML/Forms/Styling_HTML_forms" title="/en-US/docs/HTML/Forms/Styling_HTML_forms">Styling HTML forms</a>.</p>
-
-<p>Hier worden enkele klassieke zaken gestyled: fonts, grootte en randen:</p>
-
-<pre class="brush:css;">input, textarea {
- /* To make sure that all text fields have the same font settings
- By default, textareas have a monospace font */
- font: 1em sans-serif;
-
- /* To give the same size to all text field */
- width: 300px;
- -moz-box-sizing: border-box;
- box-sizing: border-box;
-
- /* To harmonize the look &amp; feel of text field border */
- border: 1px solid #999;
-}</pre>
-
-<p>HTML formulieren ondersteunen een aantal pseudoklassen om de toestand van elk element te beschrijven. Bijvoorbeeld het <span class="ng-binding text">highlighten van een aktieve widget geeft aan waar de gebruiker zich bevindt in het formulier.</span></p>
-
-<pre class="brush:css;">input:focus, textarea:focus {
- /* To give a little highlight on active elements */
- border-color: #000;
-}</pre>
-
-<p>Tekstvelden met meerdere regels hebben hun eigen stijlen. Het  {{HTMLElement("textarea")}} element is standaard een inline blok waarvan de onderkant uitgelijnd is met basislijn van de tekst. Dit is meestal niet wat men wil. Om het label en het veld uit te lijnen moet de <code>vertical-align</code> eigenschap van het {{HTMLElement("textarea")}} gewijzigd worden naar <code>top</code>.</p>
-
-<p>Let ook op de <code>resize</code> eigenschap die toelaat de grootte van het  {{HTMLelement("textarea")}} element aan te passen.</p>
-
-<pre class="brush:css;">textarea {
- /* To properly align multiline text fields with their labels */
- vertical-align: top;
-
- /* To give enough room to type some text */
- height: 5em;
-
- /* To allow users to resize any textarea vertically
- It does not work on all browsers */
- resize: vertical;
-}</pre>
-
-<p>In vele gevallen vereisen de knoppen ook een of andere stijl. Daarvoor worden zij in een {{HTMLelement("div")}} geplaatst met een buttonklasse. Hier wordt de knop uitgelijnd met de andere widgets. Om dat te doen wordt een vitueel  {{HTMLelement("label")}} geplaatst. Dit wordt gedaan door marges en uitvulling te gebruiken.</p>
-
-<pre class="brush:css;">.button {
- /* To position the buttons to the same position of the text fields */
- padding-left: 90px; /* same size as the label elements */
-}
-button {
- /* This extra margin represent roughly the same space as the space
- between the labels and their text fields */
- margin-left: .5em;
-}</pre>
-
-<p>Nu ziet hetformulier er veel mooier uit.</p>
-
-<p><img alt="" src="/files/4051/form-style.png" style="height: 260px; width: 900px;"></p>
-
-<h2 id="Verzenden_van_de_gegevens_naar_de_server">Verzenden van de gegevens naar de server</h2>
-
-<p>De laatste stap is misschien de moeilijkste. Dit is de verwerking van de formuliergegevens aan de kant van de server. Zoals gezegd is een HTML formulier meestal een eenvoudige manier om de gebruiker te vragen naar gegevens en deze naar de webserver te sturen.</p>
-
-<p>Het {{HTMLelement("form")}} element bepaalt waar en hoe de gegevens moeten verstuurd worden door de <code>action</code> en de <code>method</code> attributen.</p>
-
-<p>Maar dat is niet voldoende. De gegevens moeten ook een naam krijgen. Deze naam is belangrijk aan beide zijden. Aan de kant van de browser wordt aan ieder stukje data een naam gegeven en aan de kant van de server wordt ieder stukje aan de hand van zijn naam behandeld.</p>
-
-<p>Dus om de gegevens een naam te geven wordt een <code>name</code> attribuut gebruikt bij elke widget die een specifiek stuk data produceert:</p>
-
-<pre class="brush:html;">&lt;form action="/my-handling-form-page" method="post"&gt;
- &lt;div&gt;
- &lt;label for="name"&gt;Name:&lt;/label&gt;
- &lt;input type="text" id="name" name="user_name" /&gt;
- &lt;/div&gt;
- &lt;div&gt;
- &lt;label for="mail"&gt;E-mail:&lt;/label&gt;
- &lt;input type="email" id="mail" name="user_email" /&gt;
- &lt;/div&gt;
- &lt;div&gt;
- &lt;label for="msg"&gt;Message:&lt;/label&gt;
- &lt;textarea id="msg" name="user_message"&gt;&lt;/textarea&gt;
- &lt;/div&gt;
-
- &lt;div class="button"&gt;
- &lt;button type="submit"&gt;Send your message&lt;/button&gt;
- &lt;/div&gt;
-&lt;/form&gt;</pre>
-
-<p>In ons formulier worden 3 stuks data verzonden genaamd "<code>user_name</code>", "<code>user_email</code>" en "<code>user_message</code>". Deze gegevens worden verstuurd naar de URL "<code>/my-handling-form-page</code>"  met de HTTP POST methode.</p>
-
-<p>Op de server zal de script op de URL "<code>/my-handling-form-page</code>" de gegevens ontvangen als 3 waarden die ingesloten zijn in het HTTP verzoek. De gebruiker is verantwoordelijk hoe het script de gegevens behandelt. Elke scripttaal aan de kant van de server (PHP, Python, Ruby, Java, C#, enz.) heeft haar eigen mechanisme. Het is buiten het bestek van deze gids om dieper op dit onderwerp in te gaan maar er zijn enkele voorbeelden te vinden in het artikel <a href="/en-US/docs/HTML/Forms/Sending_and_retrieving_form_data" title="/en-US/docs/HTML/Forms/Sending_and_retrieving_form_data"><span>Sending and retrieving form data</span></a>.</p>
-
-<h2 id="Tenslotte">Tenslotte</h2>
-
-<p>Proficiat. Ons eerste HTML formulier is klaar. Hier is een live voorbeeld.</p>
-
-<table style="height: 267px; width: 772px;">
- <thead>
- <tr>
- <th scope="col" style="text-align: center;">Live voorbeeld</th>
- </tr>
- </thead>
- <tbody>
- <tr>
- <td>{{ EmbedLiveSample('A_simple_form', '460', '240', '', 'Web/Guide/HTML/Forms/My_first_HTML_form/Example') }}</td>
- </tr>
- <tr>
- </tr>
- </tbody>
-</table>
-
-<p>Het is nu tijd om dieper op deze materie in te gaan. HTML formulieren kunnen veel meer dan wat we hier beschreven hebben. Dit wordt beschreven in <a href="/en-US/docs/HTML/Forms" title="/en-US/docs/HTML/Forms">the other articles of this guide.</a></p>