Uitleg flexibele lay-out met header, menu en één, twee of drie kolommen. Past zich aan breedte van venster aan
Laatst aangepast: .

Korte omschrijving
Een‑, twee of driekoloms lay-out met (vaste) header en (vast) menu. De precieze indeling is afhankelijk van de breedte van het venster van de browser.
Deze lay-out vult altijd het hele venster van de browser, zowel in de hoogte als in de breedte. Alleen bij heel weinig inhoud kan aan de onderkant van het venster ruimte leeg blijven.
In bredere vensters staan meerdere kolommen naast elkaar. Als er genoeg tekst en dergelijke in deze kolommen staat, kunnen deze kolommen worden gescrold.
Header (geel)
Altijd even breed als het venster.
Vensters smaller dan 810 px en alle touchscreens: de header scrolt mee met de rest van de pagina. Niet hoger dan nodig om de inhoud van de header weer te kunnen geven.
Vensters breder dan 810 px, behalve touchscreens: staat altijd bovenaan het venster, scrolt niet mee. Hoogte afhankelijk van lettergrootte.
Menu (grijs/zwart op groen)
Vensters smaller dan 600 px: het menu staat onderaan de pagina en scrolt mee met de rest van de pagina. De links staan in rijen onder elkaar. Elke rij bevat twee links in de vorm van twee knoppen, die elk de halve breedte van het venster vullen.
Een link in de header bovenin brengt je naar dit menu. Een link in het menu brengt je weer terug naar boven. Deze twee links zijn alleen zichtbaar in deze smalle vensters.
Vensters breder dan 600 px: het menu staat gelijk onder de header en scrolt mee met de rest van de pagina. De links staan naast elkaar in de vorm van acht naast elkaar staande knoppen.
Vensters breder dan 810 px, behalve touchscreens: het menu staat aan de linkerkant van het venster en scrolt niet mee. De breedte is afhankelijk van de breedte van het venster. De links staan onder elkaar in de vorm van acht onder elkaar staande knoppen.
Linkerkolom (oranje)
Vensters smaller dan 700 px: de kolom wordt even breed als het venster van de browser.
Vensters breder dan 700 px: rechts van deze kolom staat een tweede kolom.
Vensters breder dan 810 px: links van deze kolom staat een menu, rechts van deze kolom staat een tweede kolom.
Vensters breder dan 1500 px: links van deze kolom staat een menu, rechts van deze kolom staan nog twee kolommen.
Tweede kolom (roze)
Vensters smaller dan 700 px: de kolom wordt even breed als het venster van de browser en staat onder de oranje kolom.
Vensters breder dan 700 px: deze kolom staat rechts van de oranje kolom en is ongeveer half zo breed als de oranje kolom.
Onderste rij of derde kolom (donkergroen)
Vensters smaller dan 700 px: de kolom wordt even breed als het venster en staat onder de roze kolom.
Vensters breder dan 700 px: de kolom wordt even breed als het venster en staat onder de oranje en roze kolom.
Vensters breder dan 810 px, behalve touchscreens: de kolom staat links van het menu en onder de oranje en roze kolom.
Vensters breder dan 1500 px: de kolom staat rechts van de roze kolom en is ongeveer half zo breed als de oranje kolom.
BELANGRIJK
Alles op deze site kan vrij worden gebruikt, met twee beperkingen:
* Je gebruikt het materiaal op deze site volledig op eigen risico. Het kan prima zijn dat er fouten in de hier verstrekte info zitten. Voor eventuele schade die door gebruik van materiaal van deze site ontstaat, in welke vorm dan ook, zijn www.css-voorbeelden.nl en medewerkers daarvan op geen enkele manier verantwoordelijk.
* Deze uitleg wordt regelmatig bijgewerkt. Het is daarom niet toegestaan deze uitleg op welke manier dan ook te verspreiden, zonder daarbij duidelijk te vermelden dat de uitleg afkomstig is van www.css-voorbeelden.nl en dat daar altijd de nieuwste versie is te vinden. Dit is om te voorkomen dat er verouderde versies worden verspreid.
Een link naar www.css-voorbeelden.nl wordt trouwens altijd op prijs gesteld.
Opmerkingen
-
Op de site en in de download is gebruik gemaakt van JavaScript. Dit JavaScript is niet essentieel voor de goede werking. Op touchscreens ziet het er altijd hetzelfde uit. Op niet-touchscreens breder dan 810 px ziet het er zonder JavaScript anders uit, maar alles werkt gewoon. Mensen die JavaScript uit hebben staan, zijn dit soort verschillen gewend. (Ik kan het weten, ik surf al jaren met NoScript.)
Deze JavaScript komt van de volgende sites:
modernizr-touch-html5shiv.js: om touch events te herkennen en om in Internet Explorer 8 nieuwere html5-elementen te herkennen;
css3-mediaqueries-js: om Internet Explorer 8 media queries te laten herkennen;
respond.js: om Internet Explorer 8 media queries te laten herkennen.
css3-mediaqueries.js en modernizr-touch-html5shiv.js zijn bijgesloten in de download, respond.js wordt alleen op de site gebruikt. Omdat dit soort scripts voortdurend wordt bijgewerkt, is het absoluut noodzakelijk dat je zélf nieuwe scripts ophaalt. Meer hierover staat bij Touchscreens herkennen met behulp van modernizr.
- Voor het maken van de gradiënten is gebruik gemaakt van de gradiënt-editor op colorzilla.com.
- Als je ankers (links binnen de pagina zelf) gebruikt, kan dit in deze lay-out (hele grote) problemen opleveren. Zie verder bij Bekende problemen.
-
Bij deze constructie staan in een breder browservenster de header en het menu stil. De tekst kan scrollen. Deze constructie kan op touchscreens grote problemen opleveren, zoals het wegvallen van (grote) delen van de pagina. Dit speelt vooral in oudere browsers, dus op termijn zal dit probleem niet meer bestaan. Maar daar heb je nu nog niets aan. Een volledig overzicht van de problemen staat bij Bekende problemen.
Deze problemen zijn zo ernstig, dat het beter is om dit voorbeeld aan te passen voor álle touchscreens. Hoe je dat kunt doen, staat bij Touchscreens herkennen met behulp van modernizr.
- Een behoorlijk deel van de css is alleen nodig, omdat alle onderdelen een achtergrondkleur hebben, voor marges, en dergelijke. Als je kijkt naar de voor dit voorbeeld essentiële css (dat is de css die in de inhoudsopgave staat en in de uitleg blauw is), zie je dat het bij deze lay-out eigenlijk om vrij weinig css gaat.
-
Als je wilt zien, hoe deze lay-out verandert bij verschillende breedtes, kun je het venster van de browser breder en smaller maken. Als je scherm niet breed genoeg is voor de grotere breedtes, kun je deze simuleren op infobyip.com. Firefox heeft onder Extra → Webontwikkelaar → Responsive Design Weergave een ingebouwde mogelijkheid om grotere breedtes weer te geven.
Overigens werkt in- en uitzoomen in Opera, Firefox en Internet Explorer 8, 9 en 10 (bureaublad-versie) in Windows, OSX en Linux hetzelfde als een smaller of breder venster. In deze browsers kun je een smaller of breder venster dus ook simuleren door in- of uitzoomen.
- In dit voorbeeld wordt soms de tekst binnen een kolom ook weer gesplitst in kolommen met behulp van de css3-eigenschap
column-.
Hierbij moet je voorkomen dat deze kolommen hoger dan het venster van de browser worden. Het is uitermate onhandig, als je van de onderkant van de eerste kolom terug omhoog moet naar de bovenkant van de tweede kolom. In dit voorbeeld gaat het overal om korte teksten, waarbij dit probleem niet speelt. - Omdat Microsoft graag haar tradities in ere houdt en dus haar browsers nooit update, zijn er afwijkingen in Internet Explorer 8. Zie verder bij Bekende problemen.
Links in deze uitleg, vooral links naar andere sites, kunnen verouderd zijn. Op de pagina met links vind je steeds de meest recente links.
Alles op deze site is gemaakt op een systeem met Linux (Kubuntu). Daarbij is vooral gebruik gemaakt van Komodo Edit, GIMP en Firefox met extensies. De pdf-bestanden zijn gemaakt met LibreOffice.
Vragen of opmerkingen? Fout gevonden? Ga naar het forum.
Achterliggend idee
Tot niet zo heel lang geleden kon je bij het maken van 'n website enigszins uitgaan van een bepaalde maat. Dat is steeds minder zo. Op de desktop verschijnen steeds meer brede schermen en bij mobiele apparaten is er helemaal een totale wildgroei aan maten, waaronder heel kleine.
Deze lay-out past zich min of meer aan de breedte van het venster van de browser aan. Om dat mogelijk te maken, zijn vrijwel alle maten niet opgegeven in een absolute eenheid als px, maar in relatieve eenheden als % en em. Dit maakt het mogelijk om onderdelen een breedte te geven, die relatief is ten opzichte van de breedte van het browservenster.
Door met behulp van css3 de breedte van het venster van de browser op te vragen, kan de lay-out worden aangepast aan de breedte van het venster.
Boven een bepaalde breedte heeft deze lay-out in principe een vaste header en een vast menu: header en menu scrollen niet mee met de pagina. Maar in veel mobiele browsers levert dit (grote) problemen op. Nieuwere browsers kunnen hier vaak wel mee overweg, maar het zal nog wel even duren, voordat iedereen zo'n nieuwere browser heeft.
Daarom wordt met behulp van JavaScript geprobeerd vast te stellen, of de browser 'touch events' herkent: aanrakingen van een touchscreen. Als dat zo is, wordt waarschijnlijk een mobiele browser gebruikt en scrollen header en menu mee met de rest van de pagina. Deze methode is niet waterdicht, maar de meeste mobiele browsers worden hier wel mee herkend.
Heel simpele mobiele apparaten, of heel oude mobiele browsers, kunnen de breedte van het venster niet doorgeven. Daarom wordt er, om aan de veilige kant te blijven, standaard vanuit gegaan dat het om een heel smal venster gaat. Pas als door de browser een grotere breedte wordt doorgegeven, wordt de lay-out aangepast aan die grotere breedte.
Niet alle mobiele apparaten kunnen goed met JavaScript uit de voeten. Daarom wordt er standaard vanuit gegaan dat het om een mobiele browser gaat. Pas als de browser meldt dat touch events niet worden ondersteund, worden – in bredere vensters – header en menu op een vaste positie gezet.
Deze volgorde zorgt ervoor dat ook de simpelste mobiele apparaten met de lay-out overweg kunnen: pas als er daadwerkelijk meer mogelijkheden aanwezig zijn, worden die gebruikt.
Het opvragen van bijvoorbeeld de breedte van het venster kan met behulp van de zogenaamde 'media queries' uit css3: een regel die begint met @media
. Met zo'n regel kun je css schrijven, die bijvoorbeeld alleen voor vensters met een bepaalde breedte geldt. Op tablets en dergelijke is de breedte van het venster van de browser normaal genomen ook de breedte van het scherm.
Door het gebruik van media queries kun je bij een bepaalde breedte de lay-out aanpassen. Ik meet niet op de specifieke breedte van één of meer apparaten, maar gewoon 'hoe het er uitziet'. Als iets te klein wordt, moet het anders worden weergegeven. Specifieke breedtes zijn meestal gericht op één fabrikant (Apple), terwijl er tientallen verschillende resoluties zijn.
De nieuwste mobiele apparaten hebben vaak een hogere resolutie dan oudere apparaten of monitors voor de desktop: de pixels staan dichter op elkaar, tot wel vier keer zo dicht. Dat zou betekenen dat een lijn van 4 px breedte op zo'n nieuwer scherm maar 1 px breed zou worden. Dat is echter niet zo, want deze apparaten doen net alsof ze 'n 'normale' pixeldichtheid hebben. Alles wordt alleen veel mooier weergegeven, omdat de pixels kleiner zijn.
(Alles? Nou, nee. Bij afbeeldingen werkt dit alleen maar als je de afbeeldingen hebt aangepast voor zo'n hoge pixeldichtheid. Als de pixels gewoon niet in de afbeelding zitten, kunnen ze ook niet worden weergegeven. Maar voor bijvoorbeeld tekst werkt het fantastisch.)
Met behulp van media queries wordt de breedte van het venster opgevraagd en kan de lay-out worden aangepast. Daarnaast wordt geprobeerd mobiele browsers te onderscheiden van desktopbrowsers.
Een mobiele browser wordt in de regel gebruikt op een touchscreen. Een mobiele browser moet daarom zogenaamde 'touch events', aanrakingen van het scherm, herkennen. Door te kijken of een browser touch events herkent, kun je met vrij grote zekerheid vaststellen, of een browser een mobiele browser is of niet.
Om te kijken of een browser touch events herkent, wordt gebruik gemaakt van modernizr. Dat is een JavaScript, waarmee je kunt vaststellen, of een browser bepaalde nieuwere eigenschappen wel of niet ondersteunt. In deze lay-out wordt alleen gekeken, of touch events worden ondersteund, maar je kunt nog veel meer met dit script.
Als de browser touch events ondersteunt, wordt door modernizr aan het >html>-element de class "touch" toegevoegd. Als de browser touch events niet ondersteunt, wordt de class "no-touch" toegevoegd.
Door nu in de css bepaalde selectors te beginnen met .touch of .no-touch, kan verschil worden gemaakt tussen browsers die wel en die geen touch events ondersteunen. Browsers die touch events niet ondersteunen, zijn in principe ook de browsers die geen problemen hebben met een vaste header en menu. Die kunnen er nu met behulp van de class "no-touch" uitgefilterd worden, waardoor andere browsers deze css niet krijgen.
Met JavaScript uit kan niet worden getest, of de browser touch events herkent of niet. Daardoor wordt de standaard-css gebruikt, waarbij er vanuit wordt gegaan dat de browser touch events niet herkent. Het ziet er dan op de desktop net zo uit als in een mobiele browser. Alles werkt, het ziet er alleen anders uit, dan wanneer JavaScript aan staat.
De css bestaat uit twee delen: algemene css, die de basis vormt voor de pagina en overal het zelfde is. Daarnaast css voor de verschillende breedtes, en voor mobiele en desktopbrowsers. Je zou voor elke breedte een eigen stylesheet kunnen maken, maar normaal genomen is dat niet zo handig. Als je aparte stylesheets maakt voor elke breedte, moet voor elke breedte een extra aanroep naar de server worden gedaan. Omdat het maar om kleine stukjes aparte css gaat, is het efficiënter alles in één stylesheet te zetten. Er wordt dan wel wat meer gedownload dan strikt noodzakelijk is, maar dat is nog altijd efficiënter dan de extra aanroep.
Ogenschijnlijk lijkt deze lay-out een samenhangend geheel: het venster wordt volledig gevuld door header, menu en kolommen. In werkelijkheid gaat het om een aantal min of meer van elkaar losstaande vlakken, die toevallig enigszins samenhangend op het scherm worden gezet.
Toevallig? Nou ja, de plaats waar ze staan, is natuurlijk niet toevallig. Maar ze hebben verder soms weinig met elkaar te maken. Zonder enig probleem zou je de header links kunnen neerzetten, of het menu rechts. Wat voor het oog een samenhangend geheel is, bestaat in werkelijkheid uit een aantal min of meer losse blokken.
Omdat de pagina in werkelijkheid uit min of meer losse blokken bestaat, geeft dat de mogelijkheid de weergave van die blokken met behulp van css aan te passen. En af te laten hangen van de breedte van het venster.
Het eerste blok is de header aan de bovenkant van het venster, die ook in de html helemaal bovenaan staat. Voor de herkenbaarheid is de achtergrond van de header geel gemaakt. De header staat in de tag <header>, wat eigenlijk een doodgewone div is, maar met een speciale semantische betekenis: de header zit erin. Omdat <header> een blok-element is, vult het normaal genomen automatisch de volle breedte van het venster van de browser.
Standaard scrolt de header gewoon mee met de rest van de pagina. De hoogte is niet meer, dan nodig is, om de inhoud van de header weer te kunnen geven.
Pas als wordt vastgesteld dat het venster breder is dan 810 px en dat de browser geen touch events herkent, scrolt de header niet meer mee, maar blijft altijd bovenin het venster staan. Dit ontstaat niet door iets aan de header te veranderen, maar door het deel gelijk onder de header (div#wrapper
) absoluut te positioneren. Binnen dat deel kan worden gescrold, maar de pagina in z'n geheel scrolt niet. Dus de header scrolt ook niet en blijft altijd op z'n plaats bovenin het venster staan.
Om alle onderdelen goed ten opzichte van elkaar te kunnen plaatsen, krijgt <header> nu een vaste hoogte. Bij een heel grote letter zou de inhoud van <header> daardoor onder de header kunnen komen te staan, over tekst en dergelijke die onder de header staat. Om dat te voorkomen, wordt overflow
op auto
gezet: als de inhoud niet in <header> past, verschijnt rechts van de header een verticale scrollbalk.
Dan houden we het deel onder de header nog over: het menu en de kolommen.
<header> kan relatief simpel een breedte krijgen, omdat <header> gewoon altijd even breed als het venster moet zijn. Voor het deel met menu en kolommen ligt het iets ingewikkelder, omdat de plaatsing van menu en kolommen afhankelijk is van de breedte van het venster en van het al dan niet herkennen van touch events door de browser. En dan moet het geheel er ook nog 'n beetje netjes uitgelijnd en zo uitzien.
Ook hier wordt weer uitgegaan van het smalste venster in een browser die touch events herkent. Pas als daadwerkelijk wordt vastgesteld dat het venster breder is, en dat de browser touch events niet herkent, wordt de lay-out aangepast.
De kleinste lay-out is bedoeld voor vensters smaller dan 600 px. Zulke kleine vensters zijn (vrijwel) altijd touchscreens. Dus het menu moet worden bediend met de vingers, en niet iedereen heeft lieflijke kleutervingertjes, waarmee je heerlijk kunt priegelen in voor bouwvakkersklauwen onbereikbare hoekjes.
Kortom: het menu heeft op hele kleine vensters relatief veel ruimte nodig. Zoveel, dat het al snel het hele venster vult. Daarom wordt het menu onderaan de pagina neergezet. Het vult daar inderdaad (vrijwel) het hele venster, maar dat is op die plaats niet erg. Zou het gelijk bovenaan de pagina staan, dan zou je bij openen van de pagina in eerste instantie alleen het menu zien.
De links uit het menu zijn elk even breed als het halve venster. Ze kunnen nu makkelijk met de vingers worden bediend, ook door bouwvakkers. Om snel weer terug naar boven te kunnen, verschijnt een extra link: 'Top'. Dit menu scrolt gewoon mee met de pagina. De knoppen in het menu zijn zo simpel mogelijk gehouden: rechthoekige grijze vlakken. Maar niets belemmert je, om ze op te leuken met allerlei toeters en bellen.


Bovenaan de pagina verschijnt linksboven in de header een extra link 'Menu', die je in één keer naar het menu onderaan brengt.
Dit is ook de reden dat het menu in de html onder de kolommen staat, helemaal onderaan in div#wrapper
: om er 'n link naartoe te kunnen maken, moet het menu een id krijgen. Je kunt dan naar dat id linken, een zogenaamd 'anker'. Dat anker komt uit op de plaats waar die id staat. Als ik naar de onderkant van de pagina wil gaan, moet die id dus onderaan de pagina staan. En omdat de id in het menu staat, moet ook het menu onderaan staan.
In deze vensters smaller dan 600 px vult elke kolom de volle breedte van het venster van de browser. De drie kolommen staan onder elkaar.
Als het venster van de browser breder dan 600 px is, is er (iets) meer ruimte. De knoppen uit het menu kunnen naast elkaar worden gezet en zijn toch nog goed met de vingers te bedienen. Omdat de knoppen nu niet meer onder elkaar, maar naast elkaar staan, kunnen ze absoluut bovenaan worden gepositioneerd, gelijk onder de header. Ze vullen nu niet meer het hele venster, en bovenaan is een logischer plaats dan helemaal onderaan.

De extra link bovenin de header naar het menu aan de onderkant, en de link vanuit het menu terug naar de bovenkant van de pagina, zijn nu niet meer nodig en worden verborgen.
Het menu scrolt nog steeds mee met de rest van de pagina. Er is nog steeds relatief weinig ruimte in het venster, en mensen zullen niet dol van geluk worden, als die weinige ruimte dan ook nog 'ns schuilgaat achter header en menu. Zelfs de rijke, subtiele, gevoelige, kunstzinnige schakering van de achtergrondkleuren in het voorbeeld verhelpt daar niets aan.
De kleine stukjes groen die je achter het menu ziet, zijn de achtergrondkleur van het menu. De knoppen in het menu zijn hier iets verfraaid met een achtergrond-gradiënt en ronde hoeken. Ik zal trouwens de eerste zijn om toe te geven, dat het nog steeds geen pareltjes van schoonheid zijn. Maar het gaat er hier niet om het mooiste menu te maken.
De kolommen vullen de volle breedte van het venster van de browser en staan onder elkaar.
In vensters breder dan 700 px is weer wat meer ruimte. Hier worden de eerste en tweede kolom niet meer onder elkaar, maar naast elkaar gezet. De eerste kolom vult ongeveer twee derde van de breedte, de tweede kolom een derde.

Dit naast elkaar plaatsen gebeurt door bij beide kolommen display: table-cell;
op te geven. Hierdoor worden beide kolommen als een cel in een tabel weergegeven, alsof je in de html <td> hebt gebruikt. Opgeven van een rij (<tr>) of tabel (<table>) is niet nodig: de browser maakt de benodigde <gt; en <table> automatisch aan, waardoor een normale tabel ontstaat. Maar omdat de browser dat automatisch afhandelt, merk je daar verder niets van.
De derde kolom is hier eigenlijk nog geen kolom, maar staat onder de eerste twee kolommen.
Een aantal mensen is nu vermoedelijk aan het bijkomen van een hartverzakking. Tabellen voor lay-out? Stond daar niet een levenslange verbanning naar Redmond op?
Nee, niet op déze tabel. Een tabel in de html hoort alleen gebruikt te worden voor tabulaire gegevens, omdat de html anders slecht toegankelijk is voor screenreaders, zoekmachines, en dergelijke. Html-tabellen zijn ook ongelooflijk moeilijk te onderhouden, zeker als ze genest zijn.
Dit is echter geen html-tabel, maar een css-tabel. En dat is heel wat anders. Deze tabel heeft geen enkele invloed op de toegankelijkheid: je verandert geen komma aan de html. De structuur van de html blijft precies hetzelfde, alleen de plaats van de onderdelen op het scherm verandert. Precies waar css voor is bedoeld.
Uiteraard moet je ook hier niet al te wild mee omgaan. Als je css-tabellen 37 niveaus diep gaat nesten, leidt dat tot dezelfde overspannenheid als bij html-tabellen.
Het grote voordeel van het gebruik van een css-tabel is hier de automatische hoogte. Normaal genomen moet je nogal wat moeite doen om de twee kolommen even hoog te maken. Door ze beide te veranderen in de cel van een tabel, krijgen ze automatisch dezelfde hoogte. Net zoals in een 'echte' tabel het geval is. Waardoor ook de achtergrondkleur van beide kolommen even ver naar beneden doorloopt, ongeacht welke kolom het langst is.
In vensters breder dan 810 px is nog wat meer ruimte. Het menu komt nu links van de kolommen te staan.

De drie kolommen staan in een gezamenlijke <article>, het menu staat daarbuiten. Dit geeft de mogelijkheid aan de linkerkant van <article> ruimte vrij te maken voor het menu.
Het is hier eigenlijk de bedoeling dat header en menu blijven staan en alleen de kolommen scrollen. Maar omdat dat in mobiele browsers tot (grote) problemen kan leiden, is daarvoor een aanvullende voorwaarde nodig. Als met behulp van het JavaScript modernizr is vastgesteld dat de browser touch events niet herkent, is het vermoedelijk geen mobiele browser. Vermoedelijk gaat het dan om een desktop of soortgelijk apparaat.
Pas in dat geval scrollen header en menu niet mee. Als de browser touch events herkent en dus vermoedelijk een mobiele browser is, blijft het menu gewoon bovenin staan als een rij naast elkaar staande knoppen.
Bij een heel grote lettergrootte zou er inhoud van het menu onder het venster van de browser kunnen komen te staan. Omdat het menu met position: fixed;
is vastgezet, zou dat op geen enkele manier meer te zien zijn. Daarom wordt voor het menu overflow op auto gezet. Als het menu nu niet binnen het browservenster past, verschijnt aan de rechterkant een verticale scrollbalk.
De derde kolom is hier eigenlijk nog geen kolom, maar staat rechts van het menu en onder de eerste twee kolommen. Omdat deze derde kolom wat breed kan worden, wordt de inhoud ervan vanaf een vensterbreedte van 810 px in twee kolommen weergegeven.
Bij een vensterbreedte van meer dan 1200 px wordt, om te lange regels te voorkomen, de tekst in de eerste (oranje) kolom zelf ook weer in twee kolommen weergegeven. Om dezelfde reden wordt de tekst in de derde kolom nu in drie kolommen weergegeven.

Bij een breedte van meer dan 1500 px, wordt ook de derde kolom naast de andere twee gezet. Omdat deze derde kolom nu smaller is, wordt de inhoud ervan weer in één kolom weergegeven.
De derde kolom wordt ook weer met behulp van display: table-cell;
naast de andere twee gezet, zoals beschreven bij Dit naast elkaar...
Hierdoor wordt ook deze derde kolom automatisch even hoog als de eerste twee.
Bij deze breedte is in alle drie de kolommen een achtergrond-afbeelding aangebracht. Dat heeft verder niet echt nut, maar het laat zien dat zoiets mogelijk is zonder veel extra werk.
Voor Internet Explorer 8 en 9 is vanzelfsprekend aparte css nodig. Dat is een van de twee echte zekerheden in het leven: Microsoft maakt geen browsers, maar gehaktmolens.
Gehaktmolens? Microsoft? Maakt die gehaktmolens? Ja. Zonder die extra's wordt de pagina namelijk in gehakt veranderd in Internet Explorer 8. In Internet Explorer 9 valt dat mee, daar is alleen hogere wiskunde nodig voor de gradiënt in het menu, want zo'n verlopende kleur maken met alleen css was kennelijk te hoog gegrepen voor Microsoft. (Hoewel, o wonder, in Internet Explorer 10 kan dit eindelijk!)
(En die tweede zekerheid? Kom op, 'n beetje zelf nadenken! Dat is de PvdA die steevast vóór de verkiezingen links is, en na de verkiezingen rechts. Vóór de verkiezingen helpen ze opa de straat over te steken, na de verkiezingen helpen ze opa van z'n centen af. Vóór de verkiezingen misbruiken ze 'n gehandicapt kind om aan zetels te komen, na de verkiezingen slopen ze zo'n beetje alle hulp voor dat soort kinderen. Maar ik dwaal mogelijk 'n heel klein beetje af.)
Voor Internet Explorer 8 is extra JavaScript nodig om de nieuwe html5-elementen en @media-regels te herkennen.
De voorvoegsels -moz-, -ms-, -o- en -webkit-
Voordat een nieuwe css-eigenschap wordt ingevoerd, is er in de regel een experimentele fase. Browsers passen het dan al toe, maar met een aangepaste naam. Tijdens deze fase kunnen problemen worden opgelost en worden veldslagen uitgevochten over hoe de standaard precies moet worden toegepast.
Als iedereen het overal over eens is en alle problemen zijn opgelost, wordt de officiële naam uit de standaard gebruikt.
De belangrijkste browsers hebben elk een eigen voorvoegsel:
Firefox: -moz-
, naar de maker: Mozilla.
Op webkit gebaseerde browsers, zoals Google Chrome en Safari: -webkit-
.
Opera: -o-
, je mag zelf bedenken waar de letter o vandaan komt (hint: Opera wordt door Opera Software gemaakt).
Internet Explorer: -ms-
, naar de maker: Microsoft. Traditiegetrouw heeft Microsoft zich hier jarenlang niets van aangetrokken, pas bij Internet Explorer 8 is Microsoft -ms-
gaan gebruiken. Omdat het ook zonder -ms-
werkt en de speciale css voor Internet Explorer toch in een aparte stylesheet staat, gebruik ik -ms-
nooit voor oudere versies dan Internet Explorer 9.
Als je css valideert met de w3c css-validator, moet je even instellen dat je geen foutmelding krijgt voor het gebruik van deze voorvoegsels.
In dit voorbeeld worden linear-gradient
, column-count
, column-rule
en column-span
gebruikt.
Zodra de experimentele fase voorbij is, wordt het voorvoegsel weggelaten. Omdat dat moment niet bij alle browsers hetzelfde is, zet je nu ook al de officiële naam erbij. Deze wordt als laatste opgegeven. Bijvoorbeeld Firefox herkent -moz-linear-gradient
. Zodra Firefox linear-gradient
gaat herkennen, zal dit -moz-linear-gradient
overrulen, omdat het er later in staat. Dat ze er beide in staan, is dus geen enkel probleem.
linear-gradient
Op dit moment moet je nog het volgende schrijven:
{-moz-linear-gradient: ...; -o-linear-gradient: ...; -webkit-linear-gradient: ...; linear-gradient: ...;}
In de toekomst kun je volstaan met:
{linear-gradient: ...;}
Internet Explorer 8 en 9 kennen linear-gradient
helemaal niet, die krijgen eigen css. Internet Explorer 10 herkent het zonder het voorvoegsel -ms-
.
column-count, column-rule en column-span
Op dit moment moet je nog het volgende schrijven:
{-moz-column-count: ...; -webkit-column-count: ...; column-count: ...;}
In de toekomst kun je volstaan met:
column-count: ...;
(Voor column-rule
en column-span
geldt hetzelfde.)
Internet Explorer 8 en 9 kennen deze eigenschappen helemaal niet. Internet Explorer 10 en Opera herkennen ze zonder de voorvoegsels -ms-
of -o-
.
Semantische elementen en WAI-ARIA
Ik heb deze twee onderwerpen samengevoegd, omdat ze veel met elkaar te maken hebben.
Semantische elementen
De meeste elementen die in html worden gebruikt, hebben een semantische betekenis. Dat wil zeggen dat je aan de gebruikte tag al (enigszins) kunt zien, wat voor soort inhoud er in het element staat. In een <h1> staat een belangrijke kop. In een <h2> staat een iets minder belangrijke kop. In een <p> staat een alinea. In een <table> staat een tabel (en geen lay-out, als het goed is!). Enz.
Door het op de goede manier gebruiken van semantische elementen, kunnen zoekmachines, screenreaders, enz. de structuur van een pagina begrijpen. De spider van een zoekmachine is redelijk te vergelijken met een blinde. Het is dus ook in je eigen belang, om semantische elementen zo goed mogelijk te gebruiken. Een site die toegankelijk is voor mensen met een handicap, is in de regel ook goed te verwerken voor een zoekmachine en maakt dus een grotere kans gevonden en bezocht te worden.
Als het goed is, wordt het uiterlijk van de pagina bepaald met behulp van css. Het uiterlijk staat hierdoor (vrijwel) los van de semantische inhoud van de pagina. Met behulp van css kun je een <h1> heel klein weergeven en een <h6> heel groot, terwijl screenreaders, zoekmachines, en dergelijke nog steeds weten dat de <h1> een belangrijke kop is.
Slechts enkele elementen, zoals <div> en <span>, hebben geen semantische betekenis. Daardoor zijn deze elementen uitstekend geschikt, om met behulp van css het uiterlijk van de pagina aan te passen: de semantische betekenis verandert niet, maar het uiterlijk wel. Voor een screenreader of zoekmachine verandert er (vrijwel) niets, voor de gemiddelde bezoeker krijgt het door de css een heel ander uiterlijk.
(De derde laag, naast html voor de inhoud en css voor het uiterlijk, is JavaScript. Die zorgt voor de interactie tussen site en bezoeker. De min of meer strikte scheiding tussen css en html aan de ene kant en JavaScript aan de andere kant is met de komst van css3 en html5 veel vager geworden. Je kunt nu bijvoorbeeld ook met css dingen langzaam verplaatsen en met html deels de invoer in formulieren controleren. Maar op JavaScript ga ik op deze site verder niet echt in.)
Html5 heeft een aantal nieuwe elementen, die speciaal zijn bedoeld om de opbouw van een pagina aan te geven. In dit voorbeeld worden hiervan <header>, <nav>, <article> en <section> gebruikt. Alle vier gedragen zich als een gewone <div>, maar dan een <div> met een semantische betekenis. Hierdoor kunnen screenreaders, zoekmachines, en dergelijke beter zien hoe de pagina is samengesteld.
<header>: bedoeld om een header in te zetten.
<nav>: bedoeld om een serie links voor navigeren in te zetten.
<article>: tekst en dergelijke die als een zelfstandig geheel kan worden gezien. In dit voorbeeld is de tekst in de kolommen <article>.
<section>: deel van een tekst. In dit voorbeeld is de eerste kolom onderverdeeld in een aantal <section>'s. De tweede en derde kolom, waarin veel minder tekst staat, zijn elk een eigen <section>.
<article>'s en <section>'s kunnen worden genest. Het gaat er alleen om dat een <article> een afgerond geheel is, en ook een deel van een <article> of <section> kan dat zijn.
Een pagina van een krant kan binnen een <article> staan. Binnen dat <article> kan een <section> Sport staan. Binnen die <section> Sport kan weer een <article> met een wedstrijdverslag staan. Binnen een <article>, want zo'n verslag is een afgerond geheel. En binnen dat verslag zouden weer <section>'s kunnen staan voor het deel voor de rust, het deel na de rust, enz.:
<article id="krant">
<section id="sport">
<article id="verslag-1">
<section id="voor-de-rust">tekst</section>
<section id="na-de-rust">tekst</section>
</article>
<article id="verslag-2">
<section id="voor-de-rust">tekst</section>
<section id="het-doelpunt">tekst</section>
<section id="de-rellen">tekst</section>
</article>
</section>
<section id="economie">
<article id="de-grootgraaiers">tekst</article>
</section>
</article>
<header> mag vaker op één pagina worden gebruikt. Een <article> zou bijvoorbeeld een eigen <header> kunnen hebben, naast de <header> voor de hele pagina.
Het is nog niet helemaal duidelijk, of dit wel op grote schaal gaat gebeuren, want er zitten fors wat haken en ogen aan, bijvoorbeeld voor zoekmachines. Daar ga ik hier dus verder niet op in. Persoonlijk denk ik vooralsnog dat één <header> per pagina het beste is.
(In dit voorbeeld wordt <footer> niet gebruikt. Voor <footer> geldt hetzelfde als voor <header>, maar zoals de naam al zegt: het is een footer.)
Met behulp van dit soort nieuwe semantische elementen kan bijvoorbeeld een screenreader in één keer een hele <header> of <nav> passeren. Alleen hebben deze nieuwe elementen één probleem: ze hebben in de praktijk nog weinig nut, omdat screenreaders en dergelijke ze nog niet herkennen. En voordat alle screenreaders en dergelijke ze herkennen, zijn we jaren verder, want screenreaders zijn peperduur (behalve het uitstekende open source NVDA).
Maar er is niets op tegen, om ze nu vast te gaan gebruiken. Op het moment dat screenreaders, zoekmachines, enz. ze gaan herkennen, is de pagina dan al hierop voorbereid. Extra werk is het eigenlijk niet. Het intypen van <nav> gaat even snel als het intypen van <div>, en het intypen van <header> gaat zelfs nog sneller dan <div id="header">, zoals nu vaak gebeurt.
WAI-ARIA
Los van semantische elementen is er nog een hulpmiddel om pagina's beter toegankelijk te maken voor screenreaders en dergelijke: WAI-ARIA-ondersteuning. WAI-ARIA staat voor Web Accessibility Initiative – Accessible Rich Internet Applications.
WAI-ARIA is een hele serie codes die bijvoorbeeld aangeven, welk deel van een pagina een menu, een header, een footer, enz. is. Daarnaast kan WAI-ARIA bij bijvoorbeeld een formulier aangeven of iets is aangevinkt of niet. Voor blinden zijn dit soort zaken uiterst belangrijk (en dus ook voor zoekmachines).
screenreaders en dergelijke kunnen al jaren WAI-ARIA-codes herkennen. Dat is nog niet het geval met de nieuwe semantische elementen uit html5, en dat zal ook nog wel even duren, want screenreaders zijn peperduur (behalve het uitstekende NVDA).
Een van de groepen met codes binnen WAI-ARIA bestaat uit de zogenaamde landmarks. Daarmee worden belangrijke onderdelen van een pagina gemarkeerd. De landmarks komen gedeeltelijk overeen met de nieuwe semantische html5-elementen. Omdat screenreaders deze landmarks al wel herkennen, zet ik ze bij de corresponderende html-elementen. In de toekomst zijn ze niet meer nodig, maar dat zal nog wel even duren.
Op deze pagina is dit enigszins van belang, omdat de volgorde op het scherm soms iets afwijkt van de volgorde in de html, en dat kan knap verwarrend zijn. Een screenreader kan niet alleen van kop naar kop, maar ook van landmark naar landmark springen. Daardoor kan bijvoorbeeld het menu toch snel worden gevonden.
In dit voorbeeld gebruik ik de landmarks banner, navigation en main. Elke landmark wordt voorafgegaan door role=
, op dezelfde manier als dat bij classes of id's gebeurt:
<header role="banner">
<nav role="navigation">
<article role="main">
De namen zijn wat eigenaardig, maar dat is historisch zo gegroeid. 'main' geeft aan dat daar de belangrijkste content van de pagina begint, de andere roles spreken voor zich.
Op de pagina met links vind je onder het kopje Toegankelijkheid → Forums, richtlijnen, links, artikelen en dergelijke meer info over WAI-ARIA.
:hover, :focus en :active voor muis, toetsenbord, touchpad en touchscreen
:hover
Omdat :hover
mogelijk niet werkt, als css uitstaat, ontbreekt of onvolledig is geïmplementeerd, moet je nooit belangrijke informatie alleen met behulp van :hover
tonen.
Je hovert over een element, als je met behulp van muis of touchpad de cursor boven dat element brengt. Hoveren kan over álle elementen. Het wordt veel gebruikt om iets van uiterlijk te laten veranderen, een pop-up te laten verschijnen, en dergelijke.
In dit voorbeeld wordt :hover
gebruikt in browservensters breder dan 810 px, waarin het menu links van de eerste kolom staat. Zodra de cursor boven een van de knoppen in het menu komt, verandert de knop van kleur. Op touchscreens werkt dit niet.
:focus
Omdat :focus
mogelijk niet werkt, als css uitstaat geïmplementeerd, ontbreekt of onvolledig is, moet je nooit belangrijke informatie alleen met behulp van :focus
tonen.
De meeste mensen gaan met een muis naar een link, invoerveld, en dergelijke. Waarna ze vervolgens klikken om de link te volgen, tekst in te voeren, of wat ze ook maar willen doen.
Er is echter 'n tweede manier om naar links, invoervelden, en dergelijke te gaan: met behulp van de Tab-toets (sommige browsers gebruiken andere toetsen, maar het principe is hetzelfde). Met behulp van de Tab-toets kun je naar links, invoervelden, en dergelijke 'springen'. Waar je staat, wordt door alle browsers aangegeven met een of ander kadertje. De link en dergelijke met het kadertje eromheen heeft focus. Dat wil zeggen dat je die link volgt, als je op de Enter-toets drukt, of dat je in dat veld tekst kunt gaan invoeren, enz.
Als iemand geen muis wil of kan gebruiken, bijvoorbeeld door 'n handicap, is deze manier om de cursor te sturen erg handig. Als de volgorde van de links, invoervelden, en dergelijke in de code niet logisch is, kun je eventueel met behulp van tabindex
'n afwijkende volgorde opgeven. De Tab-toets volgt dan die afwijkende volgorde.
Links, invoervelden, en dergelijke worden automatisch bezocht bij gebruik van de Tab-toets. Maar door aan andere elementen een tabindex te geven, kunnen ook andere elementen focus krijgen.
In dit voorbeeld wordt :focus
gebruikt in het menu. Bij gebruik van de Tab-toets worden één voor één alle knoppen in het menu afgelopen. :focus
werkt dus alleen bij gebruik van een toetsenbord.
Zodra één van de knoppen in het menu focus krijgt, verandert deze knop van kleur.
:active
Omdat :active
mogelijk niet werkt, als css uitstaat geïmplementeerd, ontbreekt of onvolledig is, moet je nooit belangrijke informatie alleen met behulp van :active
tonen.
Een element is actief, zolang je de muis boven dat element ingedrukt houdt, of – op sommige touchscreens – het element aanraakt.
In Internet Explorer ouder dan versie 8 werkte dit foutief, zoals :focus
hoort te werken, en :focus
werkte gewoon helemaal niet. Omdat Internet Explorer 8 de oudste versie is die ik (en het merendeel van de sitebouwers) nog ondersteun, speelt dit niet meer.
:active
wordt hier niet gebruikt, dus is hier verder niet van belang. Het zou hier ook redelijk zinloos zijn. Op touchscreens heeft het geen enkel nut hier, en als je met de muis op een knop drukt, moet je per definitie ook over die knop hoveren, dus dan werkt :hover
al.
Beschrijving van code en css
De code die te maken heeft met de basis van dit voorbeeld is onderstippeld blauw
. Alle voor dit voorbeeld niet-essentiële code is bruin
.
Deze uitleg hoort bij het voorbeeld dat in de download zit. Het voorbeeld uit de download verschilt iets van het voorbeeld hier op de site. In de download ontbreken bijvoorbeeld de witte vlakken met de links. Ook in de kopregels zit vaak wat verschil. Daarnaast kunnen er nog andere (meestal kleine) verschillen zijn.
Als je deze uitleg leest naast de broncode van het voorbeeld op de site, kan het dus bijvoorbeeld zijn dat 'n <h1> uit de css bij 'n <h2> uit de html hoort. Maar het gaat niet om hele grote, fundamentele afwijkingen.
Als je dit lastig vindt, kun je bovenaan de pagina de hele handel downloaden. In de download zit 'n voorbeeld dat wel naadloos aansluit op de uitleg in de download.
<!DOCTYPE html>
<html lang="nl" class="no-js">
Een document moet met een doctype beginnen om weergaveverschillen tussen browsers te voorkomen. Zonder doctype is de kans op verschillende (en soms volkomen verkeerde) weergave tussen verschillende browsers heel erg groot.
Geldige doctypes vind je op www.w3.org/QA/2002/04/valid-dtd-list.
Gebruik het volledige doctype, inclusief de eventuele url, anders werkt het niet goed.
Het hier gebruikte doctype is dat van html5.
De toevoeging class="no-js"
is bedoeld voor modernizr. Als JavaScript aanstaat, wordt dit veranderd in class="js"
. Meer daarover kun je vinden bij Touchscreens herkennen met behulp van modernizr.
<meta charset="utf-8">
Zorgt dat de browser letters met accenten en dergelijke goed kan weergeven.
utf-8 is de beste charset (tekenset), omdat deze alle talen van de wereld (en nog heel veel andere extra tekens) bestrijkt, maar toch niet meer ruimte inneemt voor de code, dan nodig is. Als je utf-8 gebruikt, hoef je veel minder entiteiten (ä
en dergelijke) te gebruiken, maar kun je bijvoorbeeld gewoon ä gebruiken.
Deze regel moet zo hoog mogelijk komen te staan, als eerste regel binnen de head, omdat hij anders door sommige browsers niet wordt gelezen.
In html5 hoeft deze regel niet langer te zijn, dan wat hier staat.
<meta name="viewport" content="width=device-width, initial-scale=1">
Mobiele apparaten variëren enorm in breedte. En dat is een probleem. Sites waren, in ieder geval tot voor kort, gemaakt voor desktopbrowsers. En die hebben, in vergelijking met bijvoorbeeld een smartphone, heel brede vensters. Hoe moet je op 'n smartphone een pagina weergeven, die is gemaakt voor de breedte van een desktop? Je kunt natuurlijk wachten tot álle sites zijn omgebouwd voor smartphones, tablets, enz., maar dan moet je waarschijnlijk heel erg lang wachten.
Mobiele browsers gokken erop dat een pagina een bepaalde breedte heeft. Safari voor mobiel bijvoorbeeld gaat ervan uit dat een pagina 980 px breed is. De pagina wordt vervolgens zoveel versmald dat hij binnen het venster van het apparaat past. Op een iPhone wordt de pagina dus veel smaller dan op een iPad. Vervolgens kan de gebruiker inzoomen op het deel van de pagina dat hij of zij wil zien.
Dit betekent ook dat bij het openen van de pagina de tekst meestal heel erg klein wordt weergegeven. (Meestal, want niet alle browsers en apparaten doen het op dezelfde manier.) Niet erg fraai, maar bedenk maar 'ns 'n betere oplossing voor bestaande sites.
Nieuwe sites of pagina's kunnen echter wel rekening houden met de veel kleinere vensters van mobiele apparaten. Deze lay-out bijvoorbeeld past zich aan de breedte van het venster aan, ook bij heel smalle vensters. Maar die stomme mobiele browser weet dat niet, dus die gaat ervan uit dat ook de heel smalle lay-out 980 px breed is, en verkleint die dan. Dat is ongeveer even behulpzaam als de gedienstige kelner die behulpzaam de stoel naar achteren trekt, net als jij wilt gaan zitten.
Om de door de browser aangeboden hulp vriendelijk maar beslist te weigeren, wordt deze tag gebruikt. Hiermee geef je aan dat de pagina is geoptimaliseerd voor mobiele apparaten.
Een iPad in portretstand bijvoorbeeld is 768 px breed. De kreet width=device-width
zegt tegen de mobiele browser dat de breedte van de weer te geven pagina gelijk is aan de breedte van het apparaat. Voor een iPad in portretstand dus 768 px. En dat klopt, want de weer te geven pagina past zich automatisch aan de breedte van het apparaat aan, omdat de pagina altijd 100% breed is. Als het apparaat 300 px breed is, is de pagina ook 300 px breed, maar nog altijd 100%.
Simpeler gezegd: je zegt tegen het mobiele apparaat dat de pagina geen vaste breedte heeft, en dat het dus niet nodig is om de weergave aan te passen.
Steeds meer mobiele apparaten krijgen een hogere resolutiedichtheid: er staan meer pixels in een inch dan bij een monitor voor de desktop het geval is. Als een lijn 4 px breed is, en de pixels staan vier keer zo dicht op elkaar als op de desktop, zou de lijn maar 1 px breed zijn op een mobiel apparaat. Het is wel een supermooie en strakke lijn, omdat je met vier dicht bij elkaar staande pixels fantastisch scherp kunt weergeven. Alleen is de lijn helaas nauwelijks te zien, omdat hij in al z'n pracht maar 1 px breed is.
Ook niet echt geweldig. Daarom geven ook deze apparaten de breedte weer, alsof de resolutie een standaarddichtheid heeft. Een retina-scherm (een scherm met een hoge resolutiedichtheid) jokt een beetje. Ook een venster van 2048 of 4096 px breed beweert 1024 px breed te zijn. Hierdoor ziet een lijn van 4 px breed er ook op zo'n scherm als 4 px breed uit, en niet als 1 of 2 px breed.
Die hoge resolutiedichtheid heeft wel zin, maar dan op een andere manier. Letters bijvoorbeeld worden al jaren getekend aan de hand van wiskundige formules, het zijn allang geen statische afbeeldingen meer. Die formules kunnen prima met die hoge resolutiedichtheid uit de voeten: een ronding in een letter is in een hogere resolutie veel fijner dan in een lagere resolutie. Ook voor hoge kwaliteit afbeeldingen is een hoge resolutiedichtheid zinvol. Het enige waar het niet zinvol is, is bij het aangeven van een maat. Een lijn van 4 px breed moet 4 px breed zijn, en niet 1 px breed in superkwaliteit.
Er staat nog een tweede deel in de tag: initial-scale=1
. Sommige mobiele apparaten zoomen een pagina gelijk in of uit. Ook weer in een poging behulpzaam te zijn. Ook dat is hier niet nodig, want de pagina past zich aan het apparaat aan. Er is ook een instructie om zoomen helemaal onmogelijk te maken, maar die gebruik ik niet. De bezoeker kan zelf nog gewoon zoomen, wat belangrijk is voor mensen die wat slechter zien.
<link rel="stylesheet" href="../../css/naam‑van‑stylesheet.css">
<!-- Instellingen voor Internet Explorer -->
<!--[if IE]>
<link rel="stylesheet" href="../../css/naam‑van‑ie‑stylesheet.css">
<![endif]-->
Dit stukje code heeft in dit voorbeeldbestand geen enkel nut. Normaal genomen is het een verwijzing naar een extern stylesheet, waarin de style staat. In dit voorbeeld verwijst de href naar een niet bestaand bestand. In html5 is de toevoeging type="text/css"
niet meer nodig, omdat dit standaard al zo staat ingesteld.
De bedoeling is dat je bovenstaande regels aanpast voor je eigen bestand. De hele style, die onder deze regels in de <head> staat, wordt dan in het externe bestand geplaatst, waar de href naar verwijst. In dat bestand komt de style precies zo te staan, zoals die nu in de <head> staat. Het bestand moet eindigen op .css.
Voordeel van een externe stylesheet is onder andere, dat deze geldig is voor alle pagina's, waaraan deze is gelinkt. 'n Verandering in de lay-out hoef je dan maar op één enkele centrale plek te aan te brengen.
In die externe stylesheet zet je alles dat in dit voorbeeld tussen <style> en </style> staat (zonder deze begin- en eindregel).
De bovenste regel is voor de algemene stylesheet, geldig voor alle browsers. Dit is gewoon 'n link die naar 'n bestand elders verwijst, waar de css in staat. Op de plaats van "../../css/naam-van-stylesheet.css"
moet je pad naar en naam van jouw stylesheet invullen.
Het eigenaardige stukje code daaronder heet een 'conditional comment' en wordt door alle browsers gezien als commentaar, omdat het tussen <!--
en -->
staat. Maar Internet Explorer herkent het, door de extra toevoegingen, als speciaal voor Internet Explorer bedoeld en zal het dus uitvoeren. Het is veiliger dan een zogenaamde 'hack', waarbij vaak gebruik wordt gemaakt van 'n fout (bug) in de browser. Dit is opzettelijk aangebracht door Microsoft en zal dus blijven werken, terwijl 'n bug gerepareerd kan worden. Op deze manier kun je 'n stylesheet alleen voor Internet Explorer opnemen.
Dit stukje geldt voor alle versies van Internet Explorer, maar je kunt het ook per versie aangeven. Met ingang van versie 10 van Internet Explorer werken conditional comments niet meer.
De link verwijst naar een aparte stylesheet voor Internet Explorer, waarin je css speciaal voor die browser zet. Op de plaats van "../../naam‑van‑ie‑stylesheet.css"
moet je pad naar en naam van je stylesheet voor Internet Explorer invullen.
De link naar het aparte stylesheet voor Internet Explorer moet ná de link naar het algemene stylesheet komen, omdat de opdrachten voor Internet Explorer die uit de algemene stylesheet dan in principe overrulen.
<style>
In html5 is de toevoeging type="text/css" niet meer nodig.
Voor de duidelijkheid staat de style hier in het bestand zelf, maar het is beter deze in een apart stylesheet te zetten, zoals hierboven beschreven. In die stylesheet komt alles wat tussen bovenstaande regel en </style> staat.
Technisch gezien is er geen enkel bezwaar om het in die stylesheet te zetten met dezelfde vreselijke lay-out, zoals ik die in dit voorbeeld gebruik. Maar als je dat doet, garandeer ik je hele grote problemen, omdat het volstrekt onoverzichtelijk is. Ik gebruik deze lay-out alleen, omdat het anders veel te veel regels worden.
Voorbeeld van 'n goede lay-out in je css:
div#header-buiten
{
position: absolute;
right: 16px;
width: 100%;
height: 120px;
background: yellow;
}
div#header-binnen
{
margin-left: 16px;
height: 120px;
text-align: center;
}
css voor alle breedtes
body
Het element waarbinnen de hele pagina staat. Veel instellingen die hier worden opgegeven, worden geërfd door de kinderen van <body>. Ze gelden voor de hele pagina, tenzij ze later worden gewijzigd. Dit geldt bijvoorbeeld voor de lettersoort, de lettergrootte en de voorgrondkleur.
font-family: Arial, Helvetica, sans-serif;
Lettersoort. Als er geen Arial is, wordt gezocht naar Helvetica. Als dat er ook niet is in ieder geval 'n lettersoort zonder schreef (dwarsstreepjes).
margin: 0; padding: 0;
Verschillende browsers hebben verschillende standaardinstellingen hiervoor. Door ze gewoon op 0 te zetten, zijn ze overal hetzelfde.
header
Alle <header>'s. Dat is er hier maar een: het deel met de gele achtergrond.
background: yellow;
Gele achtergrond.
color: black;
Voorgrondkleur zwart. Dit is onder andere de kleur van de tekst.
Hoewel dit de standaardkleur is, geef ik de kleur toch op. Hierboven heb ik een achtergrondkleur opgegeven. Sommige mensen hebben zelf de voorgrond‑ en/of achtergrondkleur veranderd, bijvoorbeeld omdat ze slecht kleuren kunnen onderscheiden. Als ik nu de achtergrondkleur verander, maar niet de voorgrondkleur, loop ik het risico dat tekstkleur en achtergrondkleur te veel op elkaar gaan lijken.
Door beide op te geven, weet ik redelijk zeker dat achtergrond- en tekstkleur genoeg van elkaar blijven verschillen. Als de gebruiker !important
heeft gebruikt, is er nog niets aan de hand, want dan veranderen achtergrond- en voorgrondkleur geen van beide.
text-align: center;
Tekst horizontaal centreren.
#top
Het element met id="top". Dit is de link bovenin de header naar het menu onderin de pagina. Hij is alleen zichtbaar in browservensters smaller dan 600 px, want alleen daar staat het menu onderaan de pagina.
background: black;
Zwarte achtergrond.
color: white;
Witte voorgrondkleur, waardoor ook de tekst wit wordt.
float: left;
Zo hoog mogelijk en dan zover mogelijk naar links zetten. Hierdoor komt hij helemaal in de linkerbovenhoek, links van de bovenste kop, te staan.
margin: 2px 0 0 2px;
Kleine marge aan boven- en linkerkant, zodat hij niet helemaal tegen de boven- en zijkant van het browservenster staat.
Als eenheid neem ik de absolute eenheid px en geen relatieve eenheid als procent of zo, omdat deze kleine afstand van 2 px altijd goed is.
padding: 3px 5px;
Omdat voor onder en links geen waarde is ingevuld, krijgen deze automatisch dezelfde waarde als boven en rechts. Hier staat dus eigenlijk 3px 5px 3px 5px
in de volgorde boven – rechts – onder – links.
Dit is relatief vrij veel padding. Hierdoor wordt het zwarte vlak wat hoger en breder, want de zwarte achtergrondkleur loopt door onder de padding. Het valt hierdoor wat meer op, dan wanneer het niet groter zou zijn dan het woord 'Menu'. Bovendien is het nu makkelijker met de vinger te bedienen.
Als eenheid neem ik de absolute eenheid px en geen relatieve eenheid als procent, omdat de link een bepaalde maat moet hebben, groot genoeg om makkelijk met de vinger te bedienen, maar ook niet groter dan dat. Een absolute eenheid is daarvoor beter dan een relatieve.
h1, h2
Alle <h1>'s en <h2>'s.
De <h1> is de belangrijkste kop van de pagina, dat is er maar eentje.
De <h2>'s zijn iets minder belangrijke kopjes dan de <h1>. Ze worden hier gebruikt om de verschillende onderdelen zoals header, menu en beschrijving aan te geven.
font-size: 1.2em;
Iets kleinere letter dan een <h1> of <h2> standaard krijgen. Door de lettergrootte aan te passen met behulp van css, kan ik het uiterlijk aanpassen, terwijl voor zoekmachines, spraakbrowsers, en dergelijke toch duidelijk blijft dat het om (belangrijke) kopregels gaat.
Dit is een vrij kleine letter voor een <h1>. Voor grotere browservensters wordt de lettergrootte van de <h1> later weer verhoogd.
Als eenheid neem ik em, zodat ook gebruikers van Internet Explorer de lettergrootte kunnen veranderen.
margin: 0;
Een <h> heeft standaard een marge aan boven- en onderkant. Die is hier niet welkom.
header h2
Alle <h2>'s binnen een <header>. Er is maar één <header>, waarbinnen maar een <h2> staat: het kopje 'Header'.
border-top: solid #aaa 1px;
Randje aan de bovenkant als afscheiding tussen de titel van dit voorbeeld en het voorbeeld zelf.
Een <h> is een blok-element. Normaal genomen wordt een blok-element automatisch even breed als zijn ouder. Dat is hier <header>. <header> is ook een blok-element, dus ook dat wordt normaal genomen even breed als z'n ouder.
De ouder van <header> is <body>. <header> wordt daardoor even breed als het venster van de browser. Dus ook <h2> wordt even breed als het venster. Waardoor ook de border aan de bovenkant de volle breedte van het venster vult.
header p
Alle paragrafen binnen een <header>. Er is hier maar één <header>, waarbinnen maar één <p> staat.
margin: 0 1%;
Omdat voor onder en links geen waarde is opgegeven, krijgen die dezelfde waarde als boven en rechts. Hier staat dus eigenlijk 0 1% 0 1%
in de volgorde boven – rechts – onder – links.
Een paragraaf heeft standaard een marge aan boven- en onderkant. Die wil ik hier niet hebben. Links en rechts wil ik wel een kleine marge, zodat de tekst nooit helemaal tegen de zijkant van het venster van de browser kan komen te staan.
Een marge in procenten wordt gemeten ten opzichte van de ouder. Dat is hier <header>, die altijd de volle breedte van het venster van de browser vult. In een smaller venster is de marge hierdoor smaller dan in een breder venster.

Overigens zul je deze marge alleen maar zien, als de tekst exact de volle breedte van <header> vult en tegen de zijkant daarvan aan staat. Bij header wordt alle tekst binnen <header> horizontaal gecentreerd. Tenzij de tekst de volle breedte vult, zal er hierdoor altijd al wat ruimte links en rechts van de tekst aanwezig zijn, waardoor je de marge niet ziet.
Op de afbeelding is de achtergrond van <header> geel. De achtergrond van de <p> is even rood gemaakt. De strook geel links van de rode achtergrond is de marge. Zonder die rode achtergrond, zou je in dit geval helemaal niet weten dat de <p> ook een marge heeft.
#een
Het element met id="een". Dit is de eerste kolom. De achtergrond hiervan is oranje.
background: orange;
Oranje achtergrondkleur.
color: black;
Voorgrondkleur zwart. Dit is onder andere de kleur van de tekst.
Hoewel dit de standaardkleur is, geef ik de kleur toch op. Hierboven heb ik een achtergrondkleur opgegeven. Sommige mensen hebben zelf de voorgrond‑ en/of achtergrondkleur veranderd, bijvoorbeeld omdat ze slecht kleuren kunnen onderscheiden. Als ik nu de achtergrondkleur verander, maar niet de voorgrondkleur, loop ik het risico dat tekstkleur en achtergrondkleur te veel op elkaar gaan lijken.
Door beide op te geven, weet ik redelijk zeker dat achtergrond- en tekstkleur genoeg van elkaar blijven verschillen. Als de gebruiker !important
heeft gebruikt, is er nog niets aan de hand, want dan veranderen achtergrond- en voorgrondkleur geen van beide.
padding: 3em 1% 1%;
Omdat voor links geen waarde is opgegeven, krijgt links automatisch dezelfde waarde als rechts. Hier staat dus eigenlijk 3em 1% 1% 1%
in de volgorde boven – rechts – onder – links.
Rechts, onder en links een padding van 1%, zodat er wat afstand is tussen de buitenkant van de kolom en de tekst.
Een padding in procenten wordt gemeten ten opzichte van de breedte van de ouder. Dit geldt ook voor de padding aan boven- en onderkant: ook die wordt gemeten ten opzichte van de breedte van de ouder, niet ten opzichte van de hoogte.
Die ouder is hier <article>, een blok-element. Een blok-element wordt normaal genomen even breed als de ouder van dat blok-element. De ouder van <article> is div#wrapper
. Ook een blok-element, dus ook dat wordt normaal genomen weer even groot als de ouder daarvan. De ouder van div#wrapper
is <body>. div#wrapper
wordt daardoor even breed als het venster van de browser.
Hierdoor is de padding bij een breed browservenster groter dan bij een smaller venster.

Aan de bovenkant is de padding een stuk groter: 3 em. Dat is om de witte kier op de afbeelding hiernaast te voorkomen.
De kopregel 'Eigenlijke inhoud van de pagina' staat buiten #een
. De oranje achtergrond van #een
is dan ook niet zonder meer zichtbaar achter deze kopregel, wat een lelijke witte kier oplevert.

Door aan de bovenkant van #een
een padding van 3 em op te geven, komt de inhoud van #een
lager te staan. Het eerste kind van #een
is de <h3> met 'Beschrijving van de onderdelen'. Deze komt dus 3 em lager te staan, net als alles daaronder. Hierdoor ontstaat aan de bovenkant van #een
een lege ruimte met een oranje achtergrondkleur, zoals op de afbeelding is te zien.

Hieronder bij article h2:first-child krijgt de eerste <h2> binnen <article>, dat is de kopregel met 'Eigenlijke inhoud van de pagina', een negatieve marge aan de onderkant. Hierdoor wordt alles wat beneden deze <h2> staat omhoog getrokken. Dat is #een
, inclusief de oranje achtergrondkleur. Die hierdoor ook achter 'Eigenlijke inhoud van de pagina' komt te staan.
Als eenheid is em genomen, zodat de padding mee verandert met de lettergrootte.
article h2:first-child
De <h2> die het eerste kind is van <article>. Dit is de <h2> met 'Eigenlijke inhoud van de pagina'.
margin: 0 0 -1.2em;
Omdat voor links geen waarde is opgegeven, krijgt links automatisch dezelfde waarde als rechts. Hier staat dus eigenlijk 0 0 -1.2em 0
in de volgorde boven – rechts – onder – links.
Links en rechts geen marge.
Een <h> heeft van zichzelf een marge aan boven- en onderkant. De marge aan de bovenkant is hier niet welkom, omdat je vrij weinig ruimte hebt in kleine browservensters (voor grotere vensters wordt verderop een marge aan de bovenkant aangebracht.)
De negatieve marge van 1,2 em aan de onderkant is bedoeld om alles onder deze <h2> iets omhoog te trekken. De uitleg daarvan staat hierboven bij padding: 3em 1% 1%;.
padding-left: 1%;
Voor het oog staat deze <h2> binnen kolom #een
met de oranje achtergrond. Maar in de html staat hij daarboven. #een
heeft bij #een aan de linkerkant een padding van 1% gekregen. Daarom wordt hier dezelfde padding aan de linkerkant aangebracht.
Een padding in procenten wordt gemeten ten opzichte van de ouder. Dat is hier <article>, dezelfde ouder als #een
heeft. Hierdoor is de padding aan de linkerkant van deze <h2> even groot als de padding aan de linkerkant van #een
, want 1% van <article> is even groot bij #een als bij deze <h2>.
article p
Alle paragrafen binnen <article>.
text-indent: 1em;
Elke eerste regel 1 em laten inspringen. Door als eenheid em te nemen, springt de regel meer of minder in bij een grotere of kleinere lettergrootte.
margin: 0;
Een <p> heeft standaard een marge aan boven- en onderkant. Die is hier niet welkom.
h3
Alle <h3>'s. Dit zijn de kopjes die bovenaan elk van de drie kolommen staan.
font-size: 1.15em;
Normaal genomen heeft een <h3> een iets grotere letter. Hier verander ik de lettergrootte naar iets kleiner dan de standaardgrootte. Door de lettergrootte aan te passen met behulp van css, kan ik het uiterlijk aanpassen, terwijl voor zoekmachines, spraakbrowsers, en dergelijke toch duidelijk blijft dat het om kopjes gaat.
Als eenheid neem ik em, zodat ook gebruikers van Internet Explorer de lettergrootte kunnen veranderen.
margin: 0;
Een <h> heeft standaard een marge aan boven- en onderkant. Die marges zijn hier niet welkom.
h4
Alle <h4>'s. Dit zijn de subkopjes binnen de oranje kolom.
margin: 0;
Een <h> heeft standaard een marge aan boven- en onderkant. Die marges zijn hier niet welkom.
#twee
Het element met id="twee". Dit is de tweede kolom. De achtergrond hiervan is roze.
background: #fcc;
Achtergrondkleurtje.
color: black;
Voorgrondkleur zwart. Dit is onder andere de kleur van de tekst.
Hoewel dit de standaardkleur is, geef ik de kleur toch op. Hierboven heb ik een achtergrondkleur opgegeven. Sommige mensen hebben zelf de voorgrond‑ en/of achtergrondkleur veranderd, bijvoorbeeld omdat ze slecht kleuren kunnen onderscheiden. Als ik nu de achtergrondkleur verander, maar niet de voorgrondkleur, loop ik het risico dat tekstkleur en achtergrondkleur te veel op elkaar gaan lijken.
Door beide op te geven, weet ik redelijk zeker dat achtergrond- en tekstkleur genoeg van elkaar blijven verschillen. Als de gebruiker !important
heeft gebruikt, is er nog niets aan de hand, want dan veranderen achtergrond- en voorgrondkleur geen van beide.
padding: 1%;
Aan alle kanten een kleine padding, zodat er wat afstand is tussen de tekst en de buitenkant van de kolom.
Een padding in procenten wordt gemeten ten opzichte van de breedte van de ouder. Dit geldt ook voor de padding aan boven- en onderkant: ook die wordt gemeten ten opzichte van de breedte van de ouder, niet ten opzichte van de hoogte.
Die ouder is hier <article>, een blok-element. Een blok-element wordt normaal genomen even breed als de ouder van dat blok-element. De ouder van <article> is div#wrapper
. Ook een blok-element, dus ook dat wordt normaal genomen weer even groot als de ouder daarvan. De ouder van div#wrapper
is <body>. div#wrapper
wordt daardoor even breed als het venster van de browser.
Hierdoor is de padding bij een breed browservenster groter dan bij een smaller venster.
#drie
Het element met id="drie". Dit is de derde kolom. In smallere browservensters is dit niet de derde kolom, maar staat dit element onder de eerste kolommen. De achtergrond hiervan is donkergroen.
background: #8fbc8f;
Achtergrondkleurtje.
color: black;
Voorgrondkleur zwart. Dit is onder andere de kleur van de tekst.
Hoewel dit de standaardkleur is, geef ik de kleur toch op. Hierboven heb ik een achtergrondkleur opgegeven. Sommige mensen hebben zelf de voorgrond‑ en/of achtergrondkleur veranderd, bijvoorbeeld omdat ze slecht kleuren kunnen onderscheiden. Als ik nu de achtergrondkleur verander, maar niet de voorgrondkleur, loop ik het risico dat tekstkleur en achtergrondkleur te veel op elkaar gaan lijken.
Door beide op te geven, weet ik redelijk zeker dat achtergrond- en tekstkleur genoeg van elkaar blijven verschillen. Als de gebruiker !important
heeft gebruikt, is er nog niets aan de hand, want dan veranderen achtergrond- en voorgrondkleur geen van beide.
padding: 1%;
Aan alle kanten een kleine padding, zodat er wat afstand is tussen de tekst en de buitenkant van de kolom.
Een padding in procenten wordt gemeten ten opzichte van de breedte van de ouder. Dit geldt ook voor de padding aan boven- en onderkant: ook die wordt gemeten ten opzichte van de breedte van de ouder, niet ten opzichte van de hoogte.
Die ouder is hier <article>, een blok-element. Een blok-element wordt normaal genomen even breed als de ouder van dat blok-element. De ouder van <article> is div#wrapper
. Ook een blok-element, dus ook dat wordt normaal genomen weer even groot als de ouder daarvan. De ouder van div#wrapper
is <body>. div#wrapper
wordt daardoor even breed als het venster van de browser.
Hierdoor is de padding bij een breed browservenster groter dan bij een smaller venster.
css voor vensters breder dan 600 px
@media screen and (min-width: 600px)
De css die hier tot nu toe staat, geldt voor alle browservensters. De css die hieronder staat, geldt alleen voor browservensters breder dan 600 px. Voor een deel is dit nieuwe css, voor een deel wordt hierboven staande css aangepast.
@media
: geeft aan dat het om css gaat die alleen van toepassing is, als aan bepaalde voorwaarden wordt voldaan. Al langer bestond de mogelijkheid, om met behulp van zo'n regel css voor bijvoorbeeld printers op te geven. css3 heeft dat uitgebreid tot bepaalde fysieke eigenschappen, zoals de breedte en hoogte van het venster van de browser.
screen
: deze regel geldt alleen voor schermweergave. Als je wilt printen, is het beter een stylesheet daarvoor te baseren op de algemene css die hierboven staat.
and
: er komt nog een voorwaarde, waar aan moet worden voldaan.
(min-width: 600px)
: het browservenster moet minstens 600 px breed zijn. Is het venster smaller, dan wordt de css die binnen deze media-regel staat genegeerd.
Gelijk na deze regel komt een { te staan, en aan het einde van de css die binnen deze regel valt een bijbehorende afsluitende }. Die zijn in de regel hierboven weggevallen, maar het geheel ziet er zo uit:
@media screen and (min-width: 600px) {
body {color: silver;}
(...) rest van de css voor deze @media-regel (...)
footer {color: gold;}
}
Voor de eerste css binnen deze media-regel staat dus een extra {
, en aan het eind staat een extra }
.
#wrapper
Het element met id="wrapper". Dit is een div, waarbinnen menu en kolommen staan. Alleen de header staat niet binnen deze div.
position: relative;
Het menu wordt gepositioneerd ten opzichte van deze div. Om dat te kunnen doen, moet deze div zelf een relatieve, absolute of fixed positie hebben. Omdat ik hier verder niets bij opgeef, heeft dit voor div#wrapper
zelf verder geen enkele invloed.
#top
Het element met id="top". Dit is de link bovenin de header naar het menu onderin de pagina, die alleen zichtbaar moet zijn in browservensters smaller dan 600 px.
display: none;
In browservensters breder dan 600 px staat het menu bovenaan de pagina, of het staat op een vaste plaats aan de linkerkant en scrolt niet mee. In beide gevallen is de link naar het menu aan de onderkant van de pagina niet nodig, dus wordt hij verborgen.
h1
Belangrijkste kop van de pagina.
font-size: 1.4em;
Hierboven is de lettergrootte verkleind tot 1,2 em. Dat is veel kleiner dan de standaardlettergrootte van een <h1>. In browservensters breder dan 600 px is er meer ruimte, daarom wordt de lettergrootte hier weer verhoogd. 1,4 em is nog steeds kleiner dan de standaardlettergrootte van een <h1>, maar die is ook wel érg groot.
Door de lettergrootte aan te passen met behulp van css, kan ik het uiterlijk aanpassen, terwijl voor zoekmachines, spraakbrowsers, en dergelijke toch duidelijk blijft dat het om de belangrijkste kop gaat.
Als eenheid gebruik ik em, zodat ook gebruikers van Internet Explorer de lettergrootte kunnen veranderen.
article
Alle <article>'s. Dat is er hier maar eentje. De kolommen staan erin.
padding-top: 55px;
Verderop wordt het menu absoluut gepositioneerd aan de bovenkant van <article>, in de vorm van een horizontale balk met knoppen. Daardoor zou het over de tekst in <article> heen komen te staan. Deze padding zet de tekst een stukje lager, zodat dat wordt voorkomen.
article h2:first-child
De <h2> die het eerste kind is van <article>. Dat is de <h2> met 'Eigenlijke inhoud van de pagina'.
margin: 0 0 -2em;
Omdat voor links geen waarde is opgegeven, krijgt links automatisch dezelfde waarde als rechts. Hier staat dus eigenlijk 0 0 -2em 0
in de volgorde boven – rechts – onder – links.
Alleen aan de onderkant een negatieve marge. Die is bedoeld om een kier in de oranje achtergrondkleur te voorkomen. Deze negatieve marge is ook al opgegeven bij article h2:first-child, waar ook de uitleg is te vinden. Hier wordt alleen de grootte van de marge aangepast.
#naar-top
Het element met id="naar-top". Dit is de laatste <li> binnen het menu met de tekst 'Top'. Als het menu onderaan de pagina staat, zoals in browservensters smaller dan 600 px het geval is, kun je met deze link weer terug naar boven gaan.
Omdat het de laatste <li> binnen de <ul> met het menu is, zou je ook de pseudo-class :last-child
kunnen gebruiken, maar die wordt niet herkend door Internet Explorer 8. Daarom is een class gebruikt.
display: none;
De link naar boven is alleen nodig in browservensters smaller dan 600 px, waar het menu onderaan komt te staan. In bredere vensters is hij overbodig en kan dus worden verborgen.
css voor vensters breder dan 700 px
@media screen and (min-width: 700px)
De css die hier tot nu toe staat, geldt ook voor browservensters breder dan 700 px. Elk venster dat minimaal 600 px breed is, is immers ook 700 px breed. De css die hieronder staat, geldt alleen voor browservensters breder dan 700 px. Voor een deel is dit nieuwe css, voor een deel wordt hierboven staande css aangepast.
De opbouw van de regel staat beschreven bij @media screen and (min-width: 600px), het enige verschil is dat het hier om een minimumbreedte van 700 px gaat.
#een
Het element met id="een". Dit is de eerste kolom. De achtergrond hiervan is oranje.
display: table-cell;
Weergeven alsof het een cel in een tabel is. Bij #twee wordt ook de tweede kolom op deze manier weergegeven. Hierdoor gedragen #een
en #twee
zich precies zoals twee cellen in een normale html-tabel zich zouden gedragen. Het grootste voordeel daarvan is dat ze beide automatisch even hoog worden. Daardoor loopt de achtergrondkleur bij beide kolommen even ver door, zonder dat hier allerlei kunstgrepen voor nodig zijn.
Ook borders tussen de kolommen worden even lang als de langste kolom, zonder dat allerlei extra grappen en grollen nodig zijn, zoals achtergrond-afbeeldingen.
Als je op deze manier met behulp van css cellen in een tabel maakt, zet de browser er automatisch een <td> en een <table> omheen. Daar merk je verder niets van.
Tabellen voor lay-out worden sterk afgeraden, en terecht. Het is een manier van coderen die nog stamt uit de tijd dat er geen css bestond. Tabellen voor lay-out zijn slecht toegankelijk voor screenreaders en dergelijke (en dus ook voor zoekmachines), zijn een nachtmerrie om te onderhouden, kosten veel meer code dan nodig is en er is ook nog 'n statistisch verband tussen tabellen en zweetvoeten aangetoond.
Kortom: een en al kommer en kwel.
En toch gebruik ik ze. Die nadelen gelden voor een html-tabel. Die is bedoeld voor tabulaire gegevens, zoals een kalender. Maar hier gaat het om css-tabellen. Er wordt niets aan de structuur van de html veranderd. Daardoor hebben deze tabellen geen enkel nadeel, wat betreft de toegankelijkheid. Ook kosten ze nauwelijks extra code.
Alleen moet je ook niet al te enthousiast css-tabellen gaan gebruiken, want een 37 niveaus diep geneste css-tabel leidt ook tot overspannenheid en zweetvoeten.
width: 63%;
Breedte. Deze css-tabel bestaat uit twee cellen. Net als in een gewone html-tabel, wordt de overblijvende breedte van 37% opgevuld door de tweede cel.
border-right: black solid 1px;
Lijntje rechts.
#een h3
Alle <h3>'s binnen het element met id="een". Dat is er hier maar eentje: de bovenste kopregel in de eerste kolom met 'Beschrijving van de onderdelen'.
margin-top: 10px;
Kleine ruimte aan de bovenkant.
Over het gebruik van display: table-cell;
is vrij weinig informatie te vinden, en al helemaal niet over de marge boven het eerste element in zo'n tabelcel.
Dat dit een marge van 10 px aan de bovenkant van de <h3> oplevert, is vrij logisch.
Maar het blijkt ook een marge aan de bovenkant van de <h3> in de tweede kolom (en in een breder browservenster ook de <h3> in de derde kolom) op te leveren.
In een echte html-tabel word de inhoud van een cel verticaal gecentreerd, tenzij je dat verandert met vertical-align
. In deze css-tabelcellen wordt de inhoud niet verticaal gecentreerd, tenzij je dat expliciet opgeeft met vertical-align
.
Er zit dus verschil tussen de weergave van html-tabelcellen en css-tabelcellen.
Kennelijk wordt bij gebruik van display: table-cell;
de grootste marge aan de bovenkant van het eerste element toegepast in élke kolom. Want als de marge aan de bovenkant van de <h3> in de tweede of derde kolom het grootst wordt gemaakt, wordt die marge boven álle <h3>'s gezet.
#twee
Het element met id="twee". Dit is de tweede kolom. De achtergrond hiervan is roze.
display: table-cell;
Dit zorgt ervoor dat de tweede kolom niet onder, maar naast de eerste kolom komt te staan. De uitleg staat bij #een.
#twee h3
Alle <h3>'s binnen het element met id="twee". Dat is er hier maar eentje: de kopregel in de tweede kolom met 'Tweede kolom'.
margin-bottom: 20px;
Kleine afstand tussen kopregel en tekst eronder.
#drie
Het element met id="drie". Dit is de derde kolom. De achtergrond hiervan is donkergroen.
In feite is dit hier nog geen kolom. Pas in nog bredere browservensters komt dit element naast de andere twee kolommen te staan. Hier staat het nog onder de eerste en tweede kolom.
border-top: black solid 1px;
Randje aan de bovenkant. Omdat #drie
onder de eerste en tweede kolom staat, staat dit randje tussen deze kolommen en #drie
.
css voor vensters breder dan 810 px
@media screen and (min-width: 810px)
De css die hier tot nu toe staat, geldt ook voor browservensters breder dan 810 px. Elk venster dat minimaal 600 of 700 px breed is, is immers ook 810 px breed. De css die hieronder staat, geldt alleen voor browservensters breder dan 810 px. Voor een deel is dit nieuwe css, voor een deel wordt hierboven staande css aangepast.
De opbouw van de regel staat beschreven bij @media screen and (min-width: 600px), het enige verschil is dat het hier om een minimumbreedte van 810 px gaat.
body
Het element waarbinnen de hele pagina staat. Veel instellingen die hier worden opgegeven, worden geërfd door de kinderen van <body>. Ze gelden voor de hele pagina, tenzij ze later worden gewijzigd. Dit geldt bijvoorbeeld voor de lettersoort, de lettergrootte en de voorgrondkleur.
font-size: 110%;
Iets groter dan standaard. 't Zal de leeftijd zijn, maar ik vind de standaardgrootte wat te klein. Nu de browservensters wat breder worden, is er ruimte voor een iets grotere letter.
.no-touch header
De <header>'s binnen een element met class="no-touch". Er is hier maar één <header>, het vlak met de gele achtergrond.
Als je in de broncode kijkt, zul je de class "no-touch" niet vinden. Deze class wordt door het JavaScript modernizr toegevoegd aan <html> bij browsers, die touch events niet herkennen. In principe werkt deze regel daardoor alleen in browsers, die touch events niet herkennen. Dat zijn (meestal) mobiele browsers.
Hoe dat precies werkt, staat bij Touchscreens herkennen met behulp van modernizr.
Om <html class="no-touch">
te kunnen zien in de broncode, moet je de gegenereerde code bekijken. In Firefox kan dat met behulp van het in Firefox ingebouwde 'Element inspecteren'. Andere browsers hebben andere manieren om gegenereerde code te bekijken.
Doordat div#wrapper
hieronder bij .no-touch #wrapper absoluut wordt gepositioneerd, scrollen de drie kolommen met tekst binnen die div. Daardoor blijft de header, ook bij scrollen, bovenaan het venster van de browser staan. Mobiele browsers hebben vaak moeite met dit soort constructies. Omdat mobiele browsers meestal touch events herkennen, missen die de class "no-touch" in <html> en negeren deze regel dus.
height: 7em;
Hoogte. Omdat deze css voor bredere vensters is, is er wat meer ruimte voor een iets hogere header dan misschien strikt nodig is. Als eenheid wordt em gebruikt, zodat bij een andere lettergrootte de verhoudingen zo goed mogelijk intact blijven.
overflow: auto;
Als de letters heel sterk worden vergroot, kan de tekst beneden de header komen te staan, over de rest van de pagina heen. Dit voorkomt dat. Als de tekst nu niet in de header past, verschijnt naast de header een verticale scrollbalk.
Dit werkt alleen maar, als het element een hoogte heeft, zoals hier het geval is.
border-bottom: black solid 1px;
Zwart randje aan de onderkant.
position: relative;
De header heeft een z-index nodig, omdat je anders het zwarte randje aan de onderkant niet overal ziet. Een z-index kan alleen worden gegeven aan een element dat absoluut, relatief of fixed is gepositioneerd. Omdat ik hier verder niets bij opgeef, heeft dit verder geen enkele invloed op <header>.
z-index: 10;
<header> is 7 em hoog. div#wrapper
wordt hieronder absoluut gepositioneerd op 7 em van de bovenkant, dus sluit precies aan op <header>. Maar <header> heeft nog een border van 1 px aan de onderkant. Die komt nog bij die 7 em. Daardoor staat div#wrapper
precies over die zwarte border heen.
Door <header> een hogere z-index te geven, komt hij boven div#wrapper
te staan, en de zwarte border aan de onderkant dus ook. Een z-index van 1 zou ook al genoeg zijn, maar de afdeling Schade en Schande heeft geleerd dat het goed is om openingen in de volgorde van de z-index te houden, zodat je er later nog 'n z-index tussen kunt stoppen.
(Ooit honderden z-indexen aangebracht. Netjes op volgorde. En toen moest er helemaal aan het begin eentje tussen. Dat doe je maar één keer...)
Een z-index kan alleen worden gebruikt als het element relatief, absoluut of fixed is gepositioneerd. Gelijk hierboven is het relatief gepositioneerd, dus dat is geregeld.
.no-touch #wrapper
Het element met id="wrapper" binnen een element met class="no-touch". Dit is een div, waarbinnen menu en kolommen staan. Alleen de header staat niet binnen deze div.
Als je in de broncode kijkt, zul je de class "no-touch" niet vinden. Deze class wordt door het JavaScript modernizr toegevoegd aan <html> bij browsers, die touch events niet herkennen. In principe werkt deze regel daardoor alleen in browsers, die touch events niet herkennen. Dat zijn (meestal) mobiele browsers.
Hoe dit verder precies werkt, staat bij Touchscreens herkennen met behulp van modernizr.
Om <html class="no-touch">
te kunnen zien in de broncode, moet je de gegenereerde code bekijken. In Firefox kan dat met behulp van het in Firefox ingebouwde 'Element inspecteren'. Andere browsers hebben andere manieren om gegenereerde code te bekijken.
Omdat div#wrapper
hieronder absoluut wordt gepositioneerd, scrollen de drie kolommen met tekst binnen die div. Daardoor blijft de header, ook bij scrollen, altijd op dezelfde plaats staan. Mobiele browsers hebben vaak moeite met dit soort constructies. Omdat mobiele browsers meestal touch events herkennen, missen die de class "no-touch" in <html> en negeren deze regel dus.
position: absolute;
Om div#wrapper
op een bepaalde plaats neer te kunnen zetten. Er wordt altijd gepositioneerd ten opzichte van de eerste voorouder die zelf een fixed, absolute of relatieve positie heeft. Als die er niet is, zoals hier het geval is, wordt gepositioneerd ten opzichte van het venster van de browser.
Aan de bovenkant wordt div#wrapper
gelijk onder de header gezet, aan de onderkant gelijk met de onderkant van het venster van de browser. div#wrapper
staat dus als het ware klem tussen header en onderkant van het venster.
Binnen div#wrapper
staat een <article>, waarbinnen de drie kolommen met tekst staan. <article> met de daarin zittende kolommen met tekst past niet binnen div#wrapper
, het is te hoog. (<article> is eigenlijk 'n gewone div, maar dan eentje met 'n semantische betekenis.)
Door overflow op auto te zetten bij div#wrapper
, ontstaat een verticale scrollbalk aan de rechterkant van div#wrapper
. <article> met de daarin zittende kolommen met tekst kan nu worden gescrold, waarbij div#wrapper
op z'n plaats blijft staan: gelijk onder de header. Omdat het scrollen binnen div#wrapper
plaatsvindt, blijft ook de header gewoon op z'n plaats staan.
(Ook het menu scrolt niet mee, maar dat wordt bij .no-touch nav met behulp van position: fixed;
vastgezet.)
top: 7em;
<header>, dat gelijk boven div#wrapper
staat, is 7 em hoog. Daarom moet div#wrapper
op 7 em vanaf de bovenkant van het venster van de browser staan, om goed op <header> aan te sluiten.
bottom: 0;
Onderkant van div#wrapper
aan de onderkant van het browservenster zetten.
overflow: auto;
Als de inhoud van div#wrapper
meer is dan erbinnen past, verschijnt een verticale scrollbalk.
Er verschijnt geen horizontale scrollbalk, omdat de inhoud van div#wrapper
automatisch aan de breedte van div#wrapper
wordt aangepast. Alleen de hoogte kan dus te groot zijn.
.no-touch article
De <article>'s binnen een element met class="no-touch". Er is hier maar één <article>. De kolommen met tekst en het menu staan erin.
Als je in de broncode kijkt, zul je de class "no-touch" niet vinden. Deze class wordt door het JavaScript modernizr toegevoegd aan <html> bij browsers, die touch events niet herkennen. In principe werkt deze regel daardoor alleen in browsers, die touch events niet herkennen. Dat zijn (meestal) mobiele browsers.
Hoe dit verder precies werkt, staat bij Touchscreens herkennen met behulp van modernizr.
Om <html class="no-touch">
te kunnen zien in de broncode, moet je de gegenereerde code bekijken. In Firefox kan dat met behulp van het in Firefox ingebouwde 'Element inspecteren'. Andere browsers hebben andere manieren om gegenereerde code te bekijken.
Bij .no-touch #wrapper is div#wrapper
absoluut gepositioneerd, wat de mogelijkheid geeft om alleen de kolommen met tekst te scrollen, terwijl header en menu altijd op dezelfde plaats blijven staan. Mobiele browsers hebben vaak moeite met dit soort constructies. Omdat mobiele browsers meestal touch events herkennen, missen die de class "no-touch" in <html>.
Daardoor wordt door die browsers deze regel genegeerd, en dat is precies de bedoeling. Als div#wrapper
niet absoluut is gepositioneerd, is deze regel ook niet nodig.
margin-left: 20%;
Een marge in procenten wordt altijd genomen ten opzichte van de ouder. Dat is hier div#wrapper
.
Normaal genomen wordt een element gewoon links in de ouder, hier div#wrapper
, neergezet. Hiermee wordt de linkerkant van <article> 20% naar links geschoven, waardoor aan de linkerkant ruimte vrijkomt voor het menu.
Door als eenheid voor de vrije ruimte procenten te nemen, past de breedte zich aan de breedte van het venster van de browser aan, waardoor de verhoudingen beter intact blijven.
De <nav>, waarin het menu staat, wordt maar 18% breed. Maar door de padding en border die daar nog bij komen, sluiten <nav> en <article> toch goed op elkaar aan.
(Feitelijk staat <article> 'n heel klein fiebeltje onder <nav>, omdat procenten en px nou eenmaal moeilijk optellen. Maar daar zie je niets van. En bij 'n site geldt, anders dan bij religie: wat je niet ziet, bestaat niet. Dat optellen van verschillende soorten eenheden gaat in css3 ook ingrijpend verbeteren met behulp van calc()
, maar op dit moment wordt dat nog onvoldoende ondersteund door de verschillende browsers.)
padding-top: 0;
Bij article is bovenaan een padding van 55 px gegeven om ruimte te maken voor het menu, dat in smallere browservensters bovenaan komt te staan. Hier wordt het menu links neergezet en is die padding dus niet nodig.
article h2:first-child
De <h2> die het eerste kind is van <article>. Dat is de <h2> met 'Eigenlijke inhoud van de pagina'.
margin: 10px 0 -2em;
Bij article h2:first-child is aan de bovenkant de marge weggehaald. In deze grotere browservensters is wat meer ruimte, daarom wordt hier weer een kleine afstand tussen deze kop en de header aangebracht.
.no-touch article h2:first-child
De <h2> die het eerste kind is van <article> binnen een element met class="no-touch". Dat is de <h2> met 'Eigenlijke inhoud van de pagina'.
Als je in de broncode kijkt, zul je de class "no-touch" niet vinden. Deze class wordt door het JavaScript modernizr toegevoegd aan <html> bij browsers, die touch events niet herkennen. In principe werkt deze regel daardoor alleen in browsers, die touch events niet herkennen. Dat zijn (meestal) mobiele browsers.
Hoe dit verder precies werkt, staat bij Touchscreens herkennen met behulp van modernizr.
Om <html class="no-touch">
te kunnen zien in de broncode, moet je de gegenereerde code bekijken. In Firefox kan dat met behulp van het in Firefox ingebouwde 'Element inspecteren'. Andere browsers hebben andere manieren om gegenereerde code te bekijken.
Bij .no-touch #wrapper is div#wrapper
absoluut gepositioneerd, wat de mogelijkheid geeft om alleen de kolommen met tekst te scrollen, terwijl header en menu altijd op dezelfde plaats blijven staan. Mobiele browsers hebben vaak moeite met dit soort constructies. Omdat mobiele browsers meestal touch events herkennen, missen die de class "no-touch" in <html>.
Daardoor wordt door die browsers deze regel genegeerd, en dat is precies de bedoeling. Als div#wrapper
niet absoluut is gepositioneerd, is deze regel ook niet nodig.
padding-left: 1.3%;
Bij article h2:first-child heeft deze <h2> aan de linkerkant een padding van 1% gekregen. Hier wordt dat verandert in 1,3%.
Deze <h2> staat boven de eerste kolom. Voor het oog lijkt hij daar deel van uit te maken. In werkelijkheid staat hij daarbuiten: zijn ouder is niet de eerste kolom #een
, maar <article>. Ook de ouder van #een
is <article>.
Omdat gelijk hieronder de padding aan de linkerkant van #een
wordt veranderd, moet ook de padding links van deze <h2> worden aangepast, anders staat de inhoud van #een
niet meer netjes uitgelijnd met deze <h2>.
Waarom #een
een padding van 1,3% krijgt, en waarom dus deze <h2> die ook moet krijgen, staat gelijk hieronder.
.no-touch #een
Het element met id="een" binnen een element met class="no-touch". Dit is de eerste kolom. De achtergrond hiervan is oranje.
Als je in de broncode kijkt, zul je de class "no-touch" niet vinden. Deze class wordt door het JavaScript modernizr toegevoegd aan <html> bij browsers, die touch events niet herkennen. In principe werkt deze regel daardoor alleen in browsers, die touch events niet herkennen. Dat zijn (meestal) mobiele browsers.
Hoe dit verder precies werkt, staat bij Touchscreens herkennen met behulp van modernizr.
Om <html class="no-touch">
te kunnen zien in de broncode, moet je de gegenereerde code bekijken. In Firefox kan dat met behulp van het in Firefox ingebouwde 'Element inspecteren'. Andere browsers hebben andere manieren om gegenereerde code te bekijken.
Bij .no-touch #wrapper is div#wrapper
absoluut gepositioneerd, wat de mogelijkheid geeft om alleen de kolommen met tekst te scrollen, terwijl header en menu altijd op dezelfde plaats blijven staan. Mobiele browsers hebben vaak moeite met dit soort constructies. Omdat mobiele browsers meestal touch events herkennen, missen die de class "no-touch" in <html>.
Daardoor wordt door die browsers deze regel genegeerd, en dat is precies de bedoeling. Als div#wrapper
niet absoluut is gepositioneerd, is deze regel ook niet nodig.
padding: 3em 1% 1% 1.3%;

Bij #een is een padding gegeven aan #een
. De padding aan de linkerkant is daar 1%, net als aan de rechterkant. Hier wordt de padding links iets vergroot. #een
staat in werkelijkheid iets onder het menu, omdat je anders door afrondingsverschillen in sommige browsers een kier krijgt tussen menu en eerste kolom.
Op de afbeelding is de achtergrondkleur van het menu even doorzichtig gemaakt, zodat te zien is dat #een
onder het menu doorloopt. Als de padding links op 1% was blijven staan, was de padding daardoor te klein geweest. De padding links wordt gewoon vanaf de linkerkant van #een
gemeten, of je die linkerkant nu ziet of niet. Een kleine verhoging met 0,3% zorgt ervoor dat de padding links weer groot genoeg is.
Een padding in procenten wordt altijd gemeten ten opzichte van de breedte van de ouder. Ook een marge aan boven- en onderkant wordt gemeten ten opzichte van de breedte van de ouder. Die ouder is hier <article>. Omdat <article> een blok-element is, wordt <article> even breed als z'n ouder. Dat is hier div#wrapper
, ook een blok-element. Dat dus ook weer even breed wordt als z'n ouder <body>, oftewel: even breed als het venster van de browser.
Omdat de breedte van div#wrapper
mee verandert met de breedte van het browservenster, verandert via deze hele keten ook deze padding in procenten mee met de breedte van het venster. Bij een breder venster is de padding dus groter dan bij een smaller venster.
#drie
Het element met id="drie". Dit is de derde kolom. In smallere browservensters is dit niet de derde kolom, maar staat dit element onder de eerste kolommen. De achtergrond hiervan is donkergroen.
-moz-column-count: 2; -webkit-column-count: 2; column-count: 2;
Als je goed kijkt, zie je dat hier in feite drie keer vrijwel hetzelfde staat: column-count: 2;
. Waarom dit drie keer wordt herhaald, staat bij De voorvoegsels -moz-, -ms-, -o- en -webkit-.
In browservensters met deze breedte is de derde kolom eigenlijk nog geen kolom: hij staat nog onder de eerste twee kolommen. Daardoor wordt hij wat breed. Lange regels zijn lastig te lezen. Door de inhoud van #drie
in twee kolommen te splitsen, blijven de regels redelijk kort.
Hierbij moet je voorkomen dat deze kolommen te hoog worden. Het is uitermate onhandig, als je van de onderkant van de eerste kolom terug omhoog moet scrollen naar de bovenkant van de tweede kolom. In dit voorbeeld gaat het overal om korte teksten, waarbij dit probleem niet speelt.
.no-touch nav h2
De <h2>'s binnen een <nav>, die weer binnen een element met class="no-touch" zit. Er is hier maar één <nav>, waarin maar één <h2> zit: het kopje met 'Menu'.
Als je in de broncode kijkt, zul je de class "no-touch" niet vinden. Deze class wordt door het JavaScript modernizr toegevoegd aan <html> bij browsers, die touch events niet herkennen. In principe werkt deze regel daardoor alleen in browsers, die touch events niet herkennen. Dat zijn (meestal) mobiele browsers.
Hoe dit verder precies werkt, staat bij Touchscreens herkennen met behulp van modernizr.
Om <html class="no-touch">
te kunnen zien in de broncode, moet je de gegenereerde code bekijken. In Firefox kan dat met behulp van het in Firefox ingebouwde 'Element inspecteren'. Andere browsers hebben andere manieren om gegenereerde code te bekijken.
Bij .no-touch #wrapper is div#wrapper
absoluut gepositioneerd, wat de mogelijkheid geeft om alleen de kolommen met tekst te scrollen, terwijl header en menu altijd op dezelfde plaats blijven staan. Mobiele browsers hebben vaak moeite met dit soort constructies. Omdat mobiele browsers meestal touch events herkennen, missen die de class "no-touch" in <html>.
Daardoor wordt door die browsers deze regel genegeerd, en dat is precies de bedoeling. Als het menu niet links wordt gepositioneerd, is deze <h2> ook niet nodig.
display: block;
Bij nav h2 is dit kopje verborgen. Als <nav> met het menu links wordt gepositioneerd, is het kopje weer welkom.
De rest van de opmaak is al opgegeven bij nav h2.
margin-top: 2.7em;
Met deze marge aan de bovenkant komt het kopje 'Menu' even hoog te staan als de kopjes 'Beschrijving van de onderdelen' en 'Tweede kolom' in de eerste en tweede kolom.
Bij zoomen blijven alle drie de kopjes op dezelfde hoogte staan. Als de lettergrootte wordt veranderd in browsers waarin dat kan, komt deze <h2> iets hoger of lager dan de andere twee kopjes te staan. Maar het gaat niet om 'n enorme afwijking.
.no-touch nav a:focus, .no-touch nav a:hover
De <a>'s binnen een <nav>, die weer binnen een element met class="no-touch" zit. Maar alleen als de <a>'s focus hebben of als erover wordt gehoverd. Er is hier maar één <nav>, waarbinnen de links van het menu zitten.
Waarom :focus
en :hover
beide zijn gebruikt, is te vinden bij :hover, :focus en :active voor muis, toetsenbord, touchpad en touchscreen.
Als je in de broncode kijkt, zul je de class "no-touch" niet vinden. Deze class wordt door het JavaScript modernizr toegevoegd aan <html> bij browsers, die touch events niet herkennen. In principe werkt deze regel daardoor alleen in browsers, die touch events niet herkennen. Dat zijn (meestal) mobiele browsers.
Hoe dit verder precies werkt, staat bij Touchscreens herkennen met behulp van modernizr.
Om <html class="no-touch">
te kunnen zien in de broncode, moet je de gegenereerde code bekijken. In Firefox kan dat met behulp van het in Firefox ingebouwde 'Element inspecteren'. Andere browsers hebben andere manieren om gegenereerde code te bekijken.
Bij .no-touch #wrapper is div#wrapper
absoluut gepositioneerd, wat de mogelijkheid geeft om alleen de kolommen met tekst te scrollen, terwijl headerheader en menu altijd op dezelfde plaats blijven staan. Mobiele browsers hebben vaak moeite met dit soort constructies. Omdat mobiele browsers meestal touch events herkennen, missen die de class "no-touch" in <html>.
Daardoor wordt door die browsers deze regel genegeerd, en dat is precies de bedoeling. :focus
en :hover
werken in vrijwel geen enkele mobiele browser goed, dus hoeven ze deze css niet te krijgen.
Het wordt hier gebruikt om de knoppen te laten verkleuren. Bij veel mobiele browsers zorgt het verkleuren van de knoppen alleen maar voor verwarring, omdat ze in die browsers alleen verkleurd zijn, als je met de back-knop van de browser teruggaat.
background: black;
Achtergrond zwart maken.
color: white;
Voorgrondkleur wit maken, waardoor ook de tekst wit wordt.
outline: none;
Een link die focus heeft, krijgt normaal genomen een outline. Daardoor weten mensen die de Tab-toets gebruiken om van link naar link te gaan, welke link focus heeft en gevolgd wordt als op Enter wordt gedrukt. Dat is hier niet nodig, omdat een link die focus heeft al verkleurt. Een outline is in dit geval foeilelijk.
css voor vensters breder dan 1200 px
@media screen and (min-width: 1200px)
De css die hier tot nu toe staat, geldt ook voor browservensters breder dan 1200 px. Elk venster dat minimaal 600, 700 of 810 px breed is, is immers ook 1200 px breed. De css die hieronder staat, geldt alleen voor browservensters breder dan 1200 px. Voor een deel is dit nieuwe css, voor een deel wordt hierboven staande css aangepast.
De opbouw van de regel staat beschreven bij @media screen and (min-width: 600px), het enige verschil is dat het hier om een minimumbreedte van 1200 px gaat.
#een section
Alle <section>'s binnen het element met id="een". Dit zijn alle <section>'s binnen de eerste kolom. Elk hoofdstukje binnen de eerste kolom staat in een eigen <section>.
-moz-column-count: 2; -webkit-column-count: 2; column-count: 2;
Als je goed kijkt, zie je dat hier in feite drie keer vrijwel hetzelfde staat: column-count: 2;
. Waarom dit drie keer wordt herhaald, staat bij De voorvoegsels -moz-, -ms-, -o- en -webkit-.
In deze bredere browservensters worden de regels binnen de eerste kolom wat lang. Daarom wordt ook de inhoud van de eerste kolom zelf in twee kolommen neergezet.
Hierbij moet je voorkomen dat deze kolommen hoger dan het venster van de browser worden. Het is uitermate onhandig, als je van de onderkant van de eerste kolom terug omhoog moet scrollen naar de bovenkant van de tweede kolom.
Hier is niet in één keer de volledige tekst binnen de eerste kolom in twee kolommen gesplitst, want dan zou dit probleem zich voordoen. De tekst binnen elke <section> wordt in twee kolommen gesplitst, dus na elke <section> beginnen de kolommen opnieuw.
Hierdoor gaat het om vrij korte stukken tekst en wordt dit heen-en-weer scrollen voorkomen.
-moz-column-rule: rgba(0, 0, 0, 0.3) solid 1px; -webkit-column-rule: rgba(0, 0, 0, 0.3) solid 1px; column-rule: rgba(0, 0, 0, 0.3) solid 1px;
Als je goed kijkt, zie je dat hier in feite drie keer vrijwel hetzelfde staat: column-rule: rgba(0, 0, 0, 0.3) solid 1px;
. Waarom dit drie keer wordt herhaald, staat bij De voorvoegsels -moz-, -ms-, -o- en -webkit-.
Met column-rule
wordt een lijntje aangebracht tussen de kolommen die met column-count
zijn gemaakt. Hierbij hoeven alleen maar kleur, stijl en breedte van de lijn opgegeven te worden, precies hetzelfde als bij border. In dit geval wordt de kleur met behulp van rgba()
opgegeven.
Het gebruik van rgba()
kan bij iets oudere browsers grote problemen geven, tot en met het volledig onleesbaar worden van tekst. Deze browsers kennen wel css en veranderen dus bijvoorbeeld wel de voorgrondkleur als die gewoon met color
is opgegeven, maar niet de achtergrondkleur als die met rgba()
is opgegeven. Met 'n beetje pech levert dat 'n tekstkleur op, die niet of nauwelijks is te onderscheiden van de achtergrond.
In dit geval is er geen risico op zo'n ramp, omdat het hier alleen maar om een lijntje tussen kolommen gaat. Ik vermeld het risico hier toch even, omdat rgba()
in oudere browsers echt tot het volledig onzichtbaar worden van tekst kan leiden.
Meestal wordt voor 'n kleur de hexadecimale notatie gebruikt, iets als color: #33ab01;
. Daarbij worden niet alleen cijfers, maar ook letters gebruikt. 0 tot en met 9 werken precies hetzelfde als altijd, maar na de 9 komen nog A, B, C, D, E en F.
Als je telt, is 't dus: 0 1 2 3 4 5 6 7 8 9 A B C D E F 10 11 12, enz. Daarbij is A gelijk aan het tientallige 10, B aan 11, enz. Op deze manier kun je met twee cijfers en/of letters 256 mogelijkheden aangeven: van 00 tot en met FF.
De eerste drie getallen bij rgba()
geven de kleur aan. Deze lopen van 0 tot en met 255, dus ook hiermee kun je 256 mogelijkheden aangeven. En omdat er drie getallen zijn levert dat 256 x 256 x 256 = 16.777.216 mogelijke kleuren op, net iets meer dan het aantal kleurpotloden in de gemiddelde kleurdoos van 'n kind.
De notatie bij rgba()
geeft dus precies evenveel mogelijkheden als de hexadecimale.
Het eerste getal staat voor rood, het tweede voor groen en het derde voor blauw (feitelijk de Engelse namen, maar de eerste letter is toevallig in het Nederlands hetzelfde). Uit deze drie kleuren zijn alle kleuren op een monitor opgebouwd.
255 wil zeggen volledig aanwezig, 0 wil zeggen helemaal ontbrekend.
255, 255, 255 levert wit op, 0 , 0 , 0 zwart.
In plaats van getallen mag je ook percentages gebruiken, bijvoorbeeld: rgba(10%, 20%, 100%, 0.3)
.
Omdat in dit voorbeeld drie keer 0 is opgegeven, levert dit een zwarte kleur op.
Het vierde getal staat voor het alfa-kanaal. Hiermee wordt de doorzichtigheid aangegeven. Dit getal loopt van 0 naar 1. Volledig doorzichtig is 0, volledig ondoorzichtig is 1.
Het getal voor het alfa-kanaal wordt als decimale breuk aangegeven, dus bijvoorbeeld 0.5 wil zeggen halfdoorzichtig. Let erop dat je 'n punt gebruikt, de Amerikaanse manier om breuken aan te geven. Als je 'n komma gebruikt, denkt de browser dat er twee verschillende getallen staan.
In dit voorbeeld is deze achtergrondkleur behoorlijk ondoorzichtig: 0.3. Hierdoor zie je de lijntjes tussen de kolommen redelijk vaag. Dat is hier mooier dan volledig zwarte lijnen. Vind ik.
border-top: rgba(0, 0, 0, 0.3) solid 1px;
Aan de bovenkant van elke <section> ook een lijntje aanbrengen. Kleur en dergelijke zijn hetzelfde als het lijntje tussen de kolommen, dat gelijk hierboven bij column-rule
wordt opgegeven.
padding: 10px 0;

Omdat voor onder en links geen waarde is opgegeven, krijgen die automatisch dezelfde waarde als boven en rechts. Hier staat dus eigenlijk 10px 0 10px 0
in de volgorde boven – rechts – onder – links.

Aan de boven- en onderkant van elke <section> een kleine padding, zodat er boven en onder de gelijk hierboven opgegeven border wat ruimte ontstaat.
#een h4
De <h4>'s binnen het element met id="een". Dit zijn de kleine tussenkopjes in de eerste kolom.
-moz-column-span: all; -webkit-column-span: all; column-span: all;
Als je goed kijkt, zie je dat hier in feite drie keer vrijwel hetzelfde staat: column-span: all;
. Waarom dit drie keer wordt herhaald, staat bij De voorvoegsels -moz-, -ms-, -o- en -webkit-.
Bij #een section is de inhoud van de eerste kolom met behulp van column-count: 2;
zelf ook weer in twee kolommen neergezet. Ook deze <h4>'s staan binnen #een section
, dus die twee kolommen gelden ook voor deze kopjes.
Deze regel geeft opdracht om de <h4>'s niet binnen één kolom, maar over de volle breedte van álle (all
) kolommen te zetten. Dat zijn er hier maar 2, maar deze eigenschap kent als waarden nou eenmaal alleen maar none
en all
. Als ik Wilders css zou willen leren, zou ik met deze eigenschap beginnen, want zelfs iemand met zo'n star zwart-wit wereldbeeld zou dit nog moeten kunnen begrijpen. (Ik moet er trouwens niet aan denken zo iemand uit te moeten leggen dat er meer kleuren zijn dan zwart en wit... Maar ik dwaal weer 'ns af, vrees ik.)
Internet Explorer 8 en 9 kennen geen kolommen, dus die negeren dit. Firefox kent wel kolommen, maar heeft column-span
nog niet geïmplementeerd. In Firefox worden deze kopjes dan ook gewoon binnen de kolom gezet. Ooit zal dit ook in Firefox worden geïmplementeerd, mogen we aannemen. Omdat onbekend is of dit met of zonder -moz-
zal gebeuren, zet ik hier voor de zekerheid ook de vorm met -moz-
neer.
text-align: center;
Tekst horizontaal centreren.
margin: -5px 0 5px;
Omdat voor links geen waarde is opgegeven, krijgt links automatisch dezelfde waarde als rechts. Hier staat dus eigenlijk -5px 0 5px 0
in de volgorde boven – rechts – onder – links.
Aan de onderkant een kleine marge tussen de kopjes en de daaronder staande tekst.
Aan de bovenkant wordt het kopje met behulp van een negatieve marge iets naar boven geplaatst. Enig experimenteren leerde dat dit, samen met de bij #een section opgegeven padding aan boven- en onderkant, het mooiste resultaat opleverde.
#drie
Het element met id="drie". Dit is de derde kolom. In smallere browservensters is dit niet de derde kolom, maar staat dit element onder de eerste kolommen. De achtergrond hiervan is donkergroen.
-moz-column-count: 3; -webkit-column-count: 3; column-count: 3;
Als je goed kijkt, zie je dat hier in feite drie keer vrijwel hetzelfde staat: column-count: 3;
. Waarom dit drie keer wordt herhaald, staat bij De voorvoegsels -moz-, -ms-, -o- en -webkit-.
In deze bredere browservensters worden de regels binnen de derde kolom behoorlijk lang. Bij de css voor vensters breder dan 810 px is de inhoud van deze kolom bij #drie al in twee kolommen gesplitst. Hier is deze kolom zo breed geworden, dat de regels toch weer wat aan de lange kant worden. Daarom wordt de inhoud van de derde kolom nu in drie kolommen gesplitst.
Hierbij moet je voorkomen dat deze kolommen hoger dan het venster van de browser worden. Het is uitermate onhandig, als je van de onderkant van de eerste kolom terug omhoog moet scrollen naar de bovenkant van de tweede kolom. Omdat het in deze kolom om vrij weinig tekst gaat, speelt dat probleem hier niet.
css voor vensters breder dan 1500 px
@media screen and (min-width: 1500px)
De css die hier tot nu toe staat, geldt ook voor browservensters breder dan 1500 px. Elk venster dat minimaal 600, 700, 810 of 1200 px breed is, is immers ook 1500 px breed. De css die hieronder staat, geldt alleen voor browservensters breder dan 1500 px. Voor een deel is dit nieuwe css, voor een deel wordt hierboven staande css aangepast.
De opbouw van de regel staat beschreven bij @media screen and (min-width: 600px), het enige verschil is dat het hier om een minimumbreedte van 1500 px gaat.
#een
Het element met id="een". Dit is de eerste kolom. De achtergrond hiervan is oranje.
background: url(101-pics/links.png) orange;
Bij #een heb ik met behulp van background
een achtergrondkleur opgegeven. Hier gebruik ik weer background om een achtergrond-afbeelding toe te voegen. Omdat ik in beide gevallen background
gebruik, moet ik hier ook de achtergrondkleur weer opnieuw opgeven.
Als je de zogenaamde 'shorthand' background
gebruikt, worden waarden die je niet invult teruggezet naar de standaardwaarde. Daardoor zou de achtergrondkleur verdwijnen, als ik die niet opnieuw opgeef.
Als ik de eerste keer background-color
had gebruikt en nu background-image
zou gebruiken, zou de achtergrondkleur wel oranje blijven, omdat bij gebruik van background-image
alleen de afbeelding wordt gewijzigd. De andere eigenschappen voor de achtergrond worden alleen bij gebruik van background
naar de standaardwaarden teruggezet.
width: 48%;
Bij #een heeft de eerste kolom een breedte van 63% gekregen, zodat er ruimte kwam voor een tweede kolom. Hier wordt er nog een derde kolom naast gezet, daarom wordt de breedte verkleind.
#twee
Het element met id="twee". Dit is de tweede kolom. De achtergrond hiervan is roze.
background: url(101-pics/midden.png) 0 1px #fcc;
Bij #twee heb ik met behulp van background
een achtergrondkleur #fcc
opgegeven. Hier gebruik ik weer background
om een achtergrond-afbeelding toe te voegen. Omdat ik in beide gevallen background
gebruik, moet ik hier ook de achtergrondkleur weer opnieuw opgeven.
Als je de zogenaamde 'shorthand' background
gebruikt, worden waarden die je niet invult teruggezet naar de standaardwaarde. Daardoor zou de achtergrondkleur verdwijnen, als ik die niet opnieuw opgeef.
Als ik de eerste keer background-color
had gebruikt en nu background-image
zou gebruiken, zou de achtergrondkleur wel #fcc
blijven, omdat bij gebruik van background-image
alleen de afbeelding wordt gewijzigd. De andere eigenschappen voor de achtergrond worden alleen bij gebruik van background
naar de standaardwaarden teruggezet.
Verder wordt hier nog de positie van de achtergrond-afbeelding aangepast met 0 1px
. Het eerste getal bepaalt de aanpassing in horizontale richting, het tweede in verticale. Horizontaal is er dus geen aanpassing, verticaal wordt de eerste achtergrond-afbeelding 1 px omlaag gezet.
De reden hiervan is de aandoening acedia. Niet van de browser of zo, maar van mij. Acedia is de Latijnse naam voor luiheid, maar ik noem mezelf liever niet lui. Als je zegt dat je acedia hebt, reageren mensen heel meelevend. Als je zegt dat je lui bent, ligt dat toch wat anders.
Bij het maken van de achtergrond-afbeeldingen ben ik wat slordig geweest. De tekst op de afbeelding met 'twee' staat 1 px hoger dan die op 'een'. Dat kan ik in 'n grafisch programma corrigeren, maar het is veel simpeler om de tweede afbeelding gewoon 1 px lager te laten beginnen. Nu staan de achtergrond-afbeeldingen toch netjes op gelijke hoogte.
width: 23%;
Tot nu toe stonden er maar twee kolommen naast elkaar. De eerste kolom had een breedte, en de tweede kolom mocht gewoon de rest van de ruimte opvullen.
Nu komt er een derde kolom naast de eerste twee te staan, dus de tweede kolom moet nu ook een breedte krijgen.
#drie
Het element met id="drie". Dit is de derde kolom. In smallere browservensters is dit niet de derde kolom, maar staat dit element onder de eerste kolommen. In vensters breder dan 1500 px, waar deze css voor is bedoeld, is dit echt een derde kolom. De achtergrond hiervan is donkergroen.
background: url(101-pics/rechts.png) 0 -1px #8fbc8f;
Bij #drie heb ik met behulp van background
een achtergrondkleur #8fbc8f
opgegeven. Hier gebruik ik weer background
om een achtergrond-afbeelding toe te voegen. Omdat ik in beide gevallen background
gebruik, moet ik hier ook de achtergrondkleur weer opnieuw opgeven.
Als je de zogenaamde 'shorthand' background
gebruikt, worden waarden die je niet invult teruggezet naar de standaardwaarde. Daardoor zou de achtergrondkleur verdwijnen, als ik die niet opnieuw opgeef.
Als ik de eerste keer background-color
had gebruikt en nu background-image
zou gebruiken, zou de achtergrondkleur wel #8fbc8f
blijven, omdat bij gebruik van background-image
alleen de afbeelding wordt gewijzigd. De andere eigenschappen voor de achtergrond worden alleen bij gebruik van background
naar de standaardwaarden teruggezet.
Verder wordt hier nog de positie van de achtergrond-afbeelding aangepast met 0 -1px
. Het eerste getal bepaalt de aanpassing in horizontale richting, het tweede in verticale. Horizontaal is er dus geen aanpassing, verticaal wordt de eerste achtergrond-afbeelding 1 px omhoog gezet.
Bij het maken van de achtergrond-afbeeldingen ben ik wat slordig geweest. De tekst op de afbeelding met 'drie' staat 1 px lager dan die op 'een'. Dat kan ik in 'n grafisch programma corrigeren, maar het is veel simpeler om de derde afbeelding gewoon 1 px hoger te laten beginnen. Nu staan de achtergrond-afbeeldingen toch netjes op gelijke hoogte.
-moz-column-count: auto; -webkit-column-count: auto; column-count: auto;
Als je goed kijkt, zie je dat hier in feite drie keer vrijwel hetzelfde staat: column-count: auto;
. Waarom dit drie keer wordt herhaald, staat bij De voorvoegsels -moz-, -ms-, -o- en -webkit-.
Tot nu toe stond deze derde kolom onder de eerste twee kolommen. Omdat hij daardoor nogal breed werd, is de inhoud met behulp van column-count
zelf ook weer in kolommen gesplitst. Nu wordt deze kolom naast de andere twee gezet, waardoor hij 'n stuk smaller wordt.
Bij deze eigenschap betekent auto
dat er geen kolommen meer worden gemaakt. (Dat is alleen zo als je column-width
niet hebt gebruikt, maar dat is hier het geval. Als je column-width
wel gebruikt, bepaalt deze eigenschap het aantal kolommen.)
display: table-cell;
Dit zorgt ervoor dat de derde kolom niet onder, maar naast de eerste en tweede kolom komt te staan. De uitleg staat bij #een.
width: 23%;
Even breed maken als de tweede kolom.
Bij de eerste en tweede kolom is al een breedte opgegeven van 48% en 23% opgegeven. Samen met de padding is de breedte van eerste en tweede kolom77%. Je zou denken dat deze derde kolom dan automatisch de resterende 23% krijgt, maar daar denken sommige browsers heel anders over. Door de breedte zelf op te geven, wordt de kolom in alle browsers 23% breed.
border-left: black solid 1px;
Zwart randje aan de rechterkant.
#drie h3
Alle <h3>'s binnen het element met id="drie". Dat is er hier maar eentje: het kopje met 'Onderste rij of derde kolom'.
margin-bottom: 20px;
Wat ruimte tussen dit kopje en de tekst eronder.
Speciaal voor Internet Explorer 8
<!--[if IE 8]>
<style>
.no-touch body #wrapper {width: 100%; overflow-x: hidden;}
.no-touch body #een, .no-touch body #twee, .no-touch body #drie {padding-right: 15px;}
</style>
<![endif]-->
Dit eigenaardige stukje code heet een 'conditional comment' en wordt door alle browsers gezien als commentaar, omdat het tussen <!--
en -->
staat. Maar Internet Explorer herkent het, door de extra toevoegingen, als speciaal voor Internet Explorer bedoeld en zal het dus uitvoeren. Het is veiliger dan een zogenaamde 'hack', waarbij vaak gebruik wordt gemaakt van 'n fout (bug) in de browser. Dit is opzettelijk aangebracht door Microsoft en zal dus blijven bestaan, terwijl 'n bug gerepareerd kan worden.
De style voor Internet Explorer moet ná de normale komen, omdat de opdrachten voor Internet Explorer dan over de normale heen gaan.
Dit stukje geldt voor Internet Explorer 8, maar je kunt het ook voor andere versies aangeven. Met ingang van versie 10 van Internet Explorer werken conditional comments niet meer.
In plaats van de style kun je ook 'n normale link naar 'n extern css-bestand aanbrengen:
<!--[if IE 8]>
<link rel="stylesheet" href="../../css/naam‑van‑ie‑stylesheet.css">
<![endif]-->
Op de plaats van "../../css/naam-van-ie-stylesheet.css"
vul je pad naar en naam van jouw stylesheet voor Internet Explorer 8 in. De css voor Internet Explorer 8 komt dan apart in die stylesheet te staan, zodat het de andere browsers niet stoort.
Het is belangrijk dat de spaties in <!--[if IE 8]>
en <![endif]-->
precies zo worden overgenomen, zoals ze hier staan.
De toevoeging type="text/css"
bij <style> of <link> is bij html5 niet meer nodig, omdat dit de standaardinstelling is.
.no-touch body #wrapper
Omdat de ondersteuning voor dit door sadisten ontworpen onding gelukkig een aflopende zaak is, ga ik maar heel beknopt op de css voor Internet Explorer 8 in. Ik heb er trouwens vaak ook geen idee van, waarom iets wel of niet werkt in dit vlooiencircus van fouten, afwijkingen en bugs. Ik begin al spontaan overal te krabben, als ik alleen maar kíjk naar wat deze browser met de code doet. (Ja, sorry, ik vind de Partij voor de Dieren een hele sympathieke partij, maar ik houd toch niet echt van vlooien.)
Je kunt vrijwel altijd uiteindelijk wel uitvinden, waarom iets wel of niet werkt, maar dat kost zeeën van tijd en, zoals gezegd: dit kreng loopt gelukkig naar z'n einde. Dus ik kan m'n tijd beter en vooral aangenamer gebruiken.
body
in de selector wordt alleen gebruikt, om genoeg specificiteit ('gewicht') te geven aan deze selector. Bij te weinig specificiteit zal deze css eerdere css niet overrulen.
width: 100%; overflow-x: hidden;
div#wrapper
even breed als de browser maken en alles wat er horizontaal niet in past gewoon helemaal niet laten zien. Dit voorkomt een volkomen overbodige horizontale scrollbalk onder de eerste twee kolommen. Vraag me niet uit welk duister krocht die scrollbalk omhoog kruipt: geen flauw idee waar 't ding vandaan komt.
.no-touch body #een, .no-touch body #twee, .no-touch body #drie
{padding-right: 15px;}
body
in de selector wordt alleen gebruikt, om genoeg specificiteit ('gewicht') te geven aan deze selector. Bij te weinig specificiteit zal deze css eerdere css niet overrulen.
Om het helemaal dolletjes gezellig te maken, plaatst Internet Explorer 8 de tekst in deze drie kolommen aan de rechterkant gewoon buiten de kolom. Een padding rechts voorkomt dat om een of andere wonderbaarlijke reden. Mogelijk had het bij volle maan over de rechterschouder werpen van wat zout ook geholpen, maar dat heb ik niet geprobeerd.
Speciaal voor Internet Explorer 9
<!--[if IE 9]>
<style>
@media screen and (min-width: 600px) {
nav a {background: url();}
}
</style>
<![endif]-->
Deze code geldt alleen voor Internet Explorer 9. Uitleg zie bij Speciaal voor Internet Explorer 8.
@media screen and (min-width: 600px)
De opbouw van de regel staat beschreven bij @media screen and (min-width: 600px).
nav a
De links binnen <nav>.
background: url();
In de knoppen bij browservensters van 600 tot 810 px breed wordt een linear-gradient gebruikt. Hierin zijn drie kleuren verwerkt. Helaas kent ook Internet Explorer 9 linear-gradient
niet. Daarvoor moet je dus iets aparts doen. In dit geval wordt gebruik gemaakt van een zogenaamde 'data-url'.
In deze op hogere wiskunde lijkende formule wordt een afbeelding weergegeven. Deze hoef je gelukkig niet zelf uit te vogelen. Als je op bijvoorbeeld colorzilla.com een gradiënt maakt, krijg je desgewenst gelijk met de normale linear-gradient bovenstaande toverformule.
De data:image/svg + xml;base64
aan het begin geeft aan dat het hier om een afbeelding gaat met MIME-type svg + xml, gecodeerd als base64. Maak je geen zorgen, de browser weet, wat dat betekent. Zelfs Internet Explorer 9.
Op deze manier kun je afbeeldingen in de css opnemen en hoef je geen extra afbeelding van de server te halen. En het is een aardige illustratie van de mogelijkheden van SVG, want je kunt er nog veel meer mee dan deze constructie, die eigenlijk overbodig zou moeten zijn. Op de pagina met links kun je onder het kopje SVG meer hierover vinden.
In browservensters breder dan 810 px is deze achtergrond niet nodig. Daar zorgt de algemene css voor hetzelfde grijze menu aan de linkerkant als in alle andere browsers. Als deze browser op een touchscreen wordt gebruikt, werkt het hetzelfde als in andere mobiele browsers: bovenaan staat een horizontale rij met knoppen. In dat geval blijft de hier opgegeven achtergrond gewoon gebruikt worden.
Html5-elementen en Internet Explorer 8
Tegen de standaard in kun je in Internet Explorer 8 (en ouder) geen css gebruiken bij onbekende elementen. Volgens de standaard hoort de browser niets te doen met een onbekend element, maar moet je er wel css aan toe kunnen kennen. Microsoft wist dit weer 'ns beter en de gevolgen daarvan zullen nog jaren blijven spelen.
In dit voorbeeld worden de voor Internet Explorer 8 onbekende html5-elementen <header>, <section>, <nav> en <article> gebruikt. De css voor deze elementen zou dus niet werken in Internet Explorer 8.
Maar als je via JavaScript deze elementen eerst even 'voorstelt' aan de browser, blijken ze plotsklaps wél herkend te worden. En kan dus gewoon css voor deze elementen worden gebruikt. (In feite worden de elementen aan de DOM toegevoegd, een soort inhoudsopgave van onder andere alle html-elementen in een pagina.)
Internet Explorer 9 kent deze elementen wel, dus hier speelt dit probleem niet meer. (Internet Explorer 9 herkent trouwens, zoals het hoort, ook onbekende elementen, zodat je daar hoe dan ook css en zo bij kunt gebruiken.)
Anders dan vaak het geval is, moet deze JavaScript in de <head> van de pagina staan. De browser moet de elementen al kennen, voordat ze kunnen worden weergegeven. Als de elementen worden gelezen, voordat ze zijn aangemaakt, worden ze gewoon genegeerd. En kan er dus ook geen css aan worden gegeven.
Het eigenlijke JavaScript is heel kort en simpel. Voor dit voorbeeld kun je in de <head> het volgende neerzetten:
<!--[if IE 8]>
<script>
document.createElement("header");
document.createElement("section");
document.createElement("nav");
document.createElement("article");
</script>
<![endif]-->
Deze code geldt alleen voor Internet Explorer 8. Uitleg zie bij Speciaal voor Internet Explorer 8.
<script>
en </script>
geven gewoon het begin en einde van het JavaScript aan. Bij html5 hoef je geen type meer op te geven, want het staat standaard op JavaScript ingesteld.
Het eigenlijke JavaScript bestaat uit:
document.createElement("header");
document.createElement("section");
document.createElement("nav");
document.createElement("article");
Door het toevoegen van zo'n regel voor een onbekend element, kan dat element nu gewoon worden gebruikt in Internet Explorer 8.
Deze JavaScript is uiterst beperkt: alleen de hier gebruikte html5-elementen worden aangemaakt, en dan alleen nog maar voor weergave op een scherm. Als je meer wilt doen dan alleen dit, is het mogelijk beter om voor Internet Explorer 8 het JavaScript op html5shiv te gebruiken. Voordeel van dit uitgebreidere script is onder andere dat standaard-instellingen als display: block;
bij bijvoorbeeld <header> ook al worden doorgegeven aan Internet Explorer 8, zodat die niet in de css hoeven.
In dit voorbeeld zul je dit soort JavaScript niet vinden in de <head>. Er wordt in dit voorbeeld ook gebruik gemaakt van het JavaScript modernizr. Het herkennen van de onbekende html5-elementen kan ook door modernizr worden gedaan, als je er de hierboven genoemde html5shiv instopt. Dat is in dit voorbeeld gedaan. Meer hierover kun je vinden bij Touchscreens herkennen met behulp van modernizr. Omdat dit soort scripts voortdurend wordt verbeterd, is het absoluut nodig dat je zélf modernizr opnieuw samenstelt en niet gewoon het script uit de download gebruikt.
Het gebruik van JavaScript betekent helaas ook dat de css in Internet Explorer 8 niet werkt, als de bezoeker JavaScript uit heeft staan. Maar normaal genomen staat JavaScript alleen uit vanwege de veiligheid. En als je ook maar enigszins met veiligheid bezig bent, dan zul je niet Internet Explorer 8 (of ouder) gebruiken. Dus het aantal mensen waarbij in deze verouderde browsers JavaScript uit zal staan, is waarschijnlijk te verwaarlozen.
Mocht dit wel een bezwaar zijn, dan zul je <nav> en dergelijke door een gewone <div> moeten vervangen.
Een andere mogelijkheid is het gebruik van <noscript>, zoals ik op de site heb gedaan. Dit moet dan alleen voor Internet Explorer 8 worden gebruikt, want andere browsers herkennen de nieuwe elementen en hebben geen JavaScript nodig. In Internet Explorer kan <noscript> alleen css krijgen via een inline-style. Het wordt dan zoiets:
<!--[if IE 8]>
<noscript>
<div style="border: dotted red 10px; padding: 5px; background: white;">
Helaas, deze pagina werkt niet goed met oudere versies van Internet Explorer zonder JavaScript.<br>
Drie mogelijkheden:<br>
* Schakel JavaScript in;<br>
* Installeer Internet Explorer 9;<br>
* Stop met die troep van Microsoft en installeer 'n échte browser zoals Firefox, Google Chrome of Opera.
</div>
</noscript>
<![endif]-->
Los van dat deze browser bij <noscript> alleen css binnen 'n inline-style kan verwerken, moet ook nog 'n extra <div> worden gebruikt. Als je de style met <noscript style="...">
zou aangeven, wordt een deel van de inhoud van <noscript> altijd getoond in Internet Explorer 8, ook al staat JavaScript aan.
media queries en Internet Explorer 8
In css3 zijn de @media-regels fors uitgebreid. Met behulp van @media kunnen nu dingen als de breedte en hoogte van het browservenster worden opgevraagd. Afhankelijk van het resultaat kan dan bepaalde css juist wel of juist niet worden gebruikt.
Helaas kan Internet Explorer 8 (en ouder) hier niet mee overweg, en omdat Microsoft bestaande browsers nooit update (op veiligheidsupdates na), zal dit ook niet veranderen. Wat Microsoft kennelijk niet kan, heeft een aantal programmeurs zelf dan maar geprobeerd voor elkaar te krijgen. Met behulp van JavaScript kan ook deze browser gebruik maken van media queries.
Helemaal probleemloos werkt dit bepaald niet. Omdat de code van deze browser geheim is en er bergen afwijkingen en bugs in zitten, werkt dit JavaScript ook niet altijd, of soms zelfs helemaal niet.
Er zijn twee veel gebruikte JavaScripts om media queries te kunnen gebruiken: css3-mediaqueries-js en respond.js.
respond.js wordt alleen op de site gebruikt bij de pagina's die achter de links in het menu zitten. Op de site zitten in die pagina's links. De opmaak van die links is afhankelijk van de breedte van het venster van de browser. In de download staan geen links op die pagina's, dus daar speelt dit niet.
Om onduidelijke redenen werkt mediaqueries.js niet goed op deze pagina's, en respond.js wel. Het zijn uiterst simpele pagina's, maar om een of andere reden gaat het mis bij gebruik van mediaqueries.js. In Internet Explorer 8 is de linkerknop leeg, de links daarin verschijnen pas als je op de knop klikt, en dan nog niet allemaal in één keer, maar een voor een. respond.js werkt wel goed.
Op de voorbeeldpagina met de lay-out is het net omgekeerd. respond.js werkt wel op de voorbeeldpagina in de download, maar doet helemaal niets in vrijwel dezelfde pagina op de site. css3-mediaqueries.js werkt goed op beide pagina's.
Hieruit blijkt weer dat je de roestbakken die Microsoft abusievelijk browser noemt, uiterst goed moet testen. En waarom deze scripts soms niet werken? Geen flauw idee. Mogelijk is daar wel achter te komen, maar het werkt, en ik kan m'n tijd beter gebruiken.
In de <head> staat het volgende stukje code:
<!--[if IE 8]>
<script src="101-files-dl/css3-mediaqueries.js"></script>
<![endif]-->
Deze code geldt alleen voor Internet Explorer versie 8. Uitleg zie bij Speciaal voor Internet Explorer 8.
css3-mediaqueries.js is het in de download bijgesloten JavaScript, dat ervoor zorgt dat Internet Explorer 8 met media queries uit de voeten kan.
Omdat dit soort scripts regelmatig wordt bijgewerkt, is het uitermate belangrijk dat je zelf dit script ophaalt van css3-mediaqueries-js en niet gewoon het script uit de download gebruikt.
Touchscreens herkennen met behulp van modernizr
In browservensters breder dan 810 px worden header en menu vastgezet. Alleen de kolommen kunnen scrollen. Dit gebeurt door het menu fixed en div#wrapper
absoluut te positioneren. Helaas kan dit in mobiele browsers tot grote problemen leiden, zoals het verdwijnen van een deel van de pagina. Dit speelt vooral in oudere browsers, nieuwere browsers kunnen beter met dit soort constructies uit de voeten. Een volledig overzicht van de problemen kun je vinden bij Bekende problemen.
Het is leuk dat dit probleem over 'n tijdje niet meer speelt, maar op dit moment zijn deze problemen nog zo groot, dat het beter is in mobiele browsers álles te laten scrollen, ook in vensters die breder zijn dan 810 px.
Hier ontstaat echter een probleem. Er is geen betrouwbare methode om te testen, welke browser je site bezoekt. Vroeger moest dat noodgedwongen vanwege alle fouten en afwijkingen in browsers voor de desktop, en zelfs met 'n heel beperkt aantal browsers ging dat heel vaak mis. (Als je zoekt op 'browser sniffing' kun je, als je van griezelverhalen houdt, je hart ophalen.)
Voor mobiel bestaan veel meer browsers dan voor de desktop. Bovendien is het aantal resoluties vrijwel onbeperkt. En dan hebben de diverse apparaten ook nog 'ns hun specifieke eigenaardigheden en bugs. Op de desktop is een monitor gewoon een monitor, op mobiele apparaten ligt dat anders. Kortom: het is onbegonnen werk om op een betrouwbare manier te kijken, welk apparaat, welke versie van een besturingssysteem en welke browser iemand gebruikt. Je gaat gegarandeerd goed werkende browsers behandelen, alsof ze problemen geven, en – erger – browsers met problemen, alsof ze goed werken.
Dat was 'n inleiding om vrolijk van te worden: grote problemen en geen oplossing, want browser sniffing werkt niet betrouwbaar.
Er zijn mogelijkheden om op de server te kijken, of de site wordt bezocht door een mobiele browser of door een desktopbrowser, en afhankelijk daarvan een pagina voor mobiel of voor de desktop te sturen. Maar dan zit je in feite met twee (of nog meer) verschillende pagina's. Op de pagina met links vind je onder Mobiele apparatuur → Validators, snelheid testen, browser sniffing, en dergelijke links naar sites die hier bij kunnen helpen.
In dit voorbeeld wordt van één pagina uitgegaan. Om toch verschil te kunnen maken tussen mobiele browsers en browsers voor de desktop, wordt gekeken of de browser 'touch events' herkent. (Hartelijke verontschuldigingen en zo, maar er bestaan gewoon geen gangbare Nederlandse woorden voor dit soort Engelse termen. Bij 'aanrakings-evenement' denk ik persoonlijk niet direct aan een browser, en bij 'aanrakings-belevenis' ga ik echt aan héle andere dingen denken, die ik liever privé houd.)
Een browser die touch events herkent, zal in de regel een mobiele browser zijn. Een browser die touch events niet herkent, zal in de regel een desktopbrowser zijn. Als een desktopbrowser ten onrechte voor een mobiele browser wordt aangezien, is dat niet zo'n ramp. Alles werkt en ziet er goed uit en zo, alleen scrolt de hele pagina, inclusief header en menu.
Als een mobiele browser voor een desktopbrowser wordt aangezien, kan dat vervelender zijn. Niet als de mobiele browser met deze constructie uit de voeten kan, maar dat is dus niet altijd het geval. Bij de geteste browsers is dat het geval bij Opera Mini op de iPad. In portretstand gaat het goed, want dan is het venster maar 768 px breed en scrolt de hele pagina. Maar in landschapsstand is het venster 1024 px breed. En Opera Mini meldt, ten onrechte, dat het geen touch events herkent, en wordt dus voor een desktopbrowser aangezien. (Wat er precies misgaat staat uitgebreider bij Bekende problemen.)
Een echt waterdichte oplossing is er niet voor dit probleem. Browser sniffing is onbetrouwbaar, en bij detectie op de server zit je met meerdere pagina's. Er wordt wel gewerkt aan dit probleem, en in css4 is het mogelijk opgelost, maar dat is voorlopig nog (verre) toekomstmuziek.
Het testen op het al dan niet herkennen van touch events gebeurt met behulp van een JavaScript: modernizr . Dit is een hele kleine JavaScript-bibliotheek die kan testen, of een browser bepaalde mogelijkheden wel of niet heeft. Het gaat dan vooral om css3- en html5-mogelijkheden, maar ook testen op touch events kan.
Op de site van modernizr kun je aangeven, waarop je wilt testen. Er wordt dan een script op maat gemaakt, zodat het zo klein mogelijk is. Dit script test vervolgens, of een browser iets wel of niet kan. Afhankelijk daarvan wordt aan de tag <html> een bepaalde class toegevoegd. In het geval van touch events is die class 'touch' of 'no-touch'. Dit geeft de mogelijkheid om, zonder verder JavaScript of zo nodig te hebben, aparte css te schrijven voor touchscreens en voor andere schermen.
Css voor touchscreens laat je gewoon voorafgaan door .touch
, en css voor andere schermen door .no-touch
. Omdat in <html> één van deze twee aanwezig is, hoef je de selectors voor touchscreens alleen maar met .touch
te beginnen, en die voor andere schermen met .no-touch
. css die voor alle schermen hetzelfde is, laat je gewoon niet beginnen met .touch
of .no-touch
, zodat het op alle schermen werkt.
Omdat de meest simpele browsers de grootste problemen hebben met deze lay-out, wordt er standaard vanuit gegaan dat het om een mobiele browser gaat. Pas als de browser daadwerkelijk meldt dat touch events niet worden herkend, wordt de css voor een vaste header en menu gebruikt.
De meest simpele browsers zitten in de regel ook op de kleinste apparaten. Daarom wordt ook standaard uitgegaan van een heel klein browservenster. Pas als de browser meldt dat het venster breder is, wordt de css voor bredere vensters gebruikt.
In de download zit het gebruikte JavaScript bijgesloten als modernizr-touch-html5shiv.js. Dit script bevat meer dan alleen nodig is om touch events te detecteren. Het zorgt er ook voor dat Internet Explorer 8 (en ouder) html5-elementen herkennen. Je zou dat ook in een apart script kunnen doen, maar modernizr kan die twee scripts combineren.
Het is belangrijk zelf een nieuw script aan te maken op de site van modernizr, want dit soort scripts wordt voortdurend bijgewerkt. Het script dat is bijgesloten in de download, kan inmiddels verouderd zijn.
Het JavaScript kun je aanmaken op modernizr.com/download. Om touch events te kunnen detecteren, heb ik daar onder Misc. 'touch events' aangevinkt. Verder moet je, om classes bij <html> aan te laten maken, onder 'Extra' nog aanvinken 'Add CSS Classes'.
Verder is nog aangevinkt 'html5shiv v3.4', zodat Internet Explorer 8 html5-elementen herkent. Als je in plaats hiervan 'html5shiv v3.4 w/ printshiv' aanvinkt, kunnen deze elementen ook nog worden geprint door Internet Explorer 8.
Na het aanvinken van wat je in het JavaScript wilt hebben, klik je op de knop 'GENERATE!' Gelijk onder die knop staat nu het JavaScript. Dat is heel compact, tenzij je gelijk eronder een vinkje zet bij 'Don't Minify Source'. Ik heb daar geen vinkje gezet, want ik ga niets aan dit JavaScript veranderen. Dus ik vind het prima, als het script zo klein mogelijk is, ook al wordt het daar volstrekt onleesbaar door.
Het gegenereerde JavaScript kopieer je en plak je op de plaats, waar het script moet komen te staan. Op mijn site bijvoorbeeld is dat in de folder 'js'.
Dit JavaScript wordt gelijk onder de link naar de style in de <head> gezet:
<script src="pad-en-naam.js"></script>
(In html5 is het type niet meer nodig bij een script, omdat standaard van JavaScript wordt uitgegaan.)
Aan de tag <html> voeg je de classnaam 'no-js' toe:
<html lang="nl" class="no-js">
Aan no-js
worden door modernizr één of meer andere andere classes toegevoegd, afhankelijk van waarop wordt getest. In het geval van testen op touch events wordt er touch
(aanwezig) of no-touch
(niet aanwezig) toegevoegd. En no-js
wordt altijd vervangen door js
.
Altijd? Nee. Niet als JavaScript uitstaat, want dan werkt modernizr niet. Dat is een zwak punt van modernizr: het werkt niet, als JavaScript ontbreekt of uitstaat. Maar in de praktijk vallen de beperkingen hiervan erg mee. Bovendien heb je ook nog de mogelijkheid om no‑js
in de selector te verwerken. no-js
wordt immers alleen door js
vervangen, als JavaScript aanstaat. Dit geeft de mogelijkheid afwijkende css te geven, als JavaScript uitstaat.
Zonder JavaScript komt er geen no-touch
bij <html> te staan, dus wordt er dan vanuit gegaan dat het om een mobiele browser gaat. Er kan dus alleen ten onrechte een desktopbrowser worden aangezien voor een mobiele browser, en dat kan alleen als JavaScript uit staat. Dat is geen echt probleem, want ook dan zie je een fatsoenlijke pagina, alleen kan de hele pagina scrollen. Het is al mooi als alles werkt, want heel vaak is dat niet het geval zonder JavaScript. En ik kan het weten, want ik surf al jaren met JavaScript standaard uit.
Als modernizr goed is geïnstalleerd, zou je in de broncode bij <html> het volgende moeten zien:
<html lang="nl" class=" js no-touch">
of
<html lang="nl" class=" js touch">
Maar als je nu spoorslags in de broncode gaat controleren, of dit klopt, zul je zien dat dit niet zo is. Als je gewoon de broncode bekijkt, zie je precies wat daar staat: de broncode. En daarin staat <html lang="nl" class="no-js">
, dus dat zie je.
Wat je wílt zien, is de door JavaScript gegenereerde code. Die kun je in Firefox zien met het in Firefox ingebouwde 'Element inspecteren'. Andere browsers hebben soortgelijke mogelijkheden om gegenereerde code te bekijken.
De code aanpassen aan je eigen ontwerp
- Als je dit voorbeeld gaat aanpassen voor je eigen site, houdt het dan in eerste instantie zo eenvoudig mogelijk. Ga vooral geen details invullen.
-
Gebruik vooral geen FrontPage, Publisher of Word (alle drie van Microsoft). Deze programma's maken niet-standaard code die alleen goed te bekijken is in Internet Explorer. In alle andere browsers zie je grotendeels bagger, áls je al iets ziet.
Publisher en Word zijn niet bedoeld om websites mee te maken. FrontPage is zwaar verouderd en wordt niet meer onderhouden door Microsoft. Als je beslist iets van Microsoft wilt gebruiken, schaf dan (voor honderden euro's) een nieuwer programma aan, dat zich wel aan de standaarden houdt.
Je kunt natuurlijk ook een goed gratis programma gebruiken. Links naar dat soort programma's vind je op de pagina met links onder Gereedschap → wysiwyg-editor.
Maar het allerbeste is om gewoon zelf html, css, enz. te leren, omdat zelfs het allerbeste programma het nog steeds zwaar verliest van 'n op de juiste manier met de hand gemaakte pagina.
-
Ik maak zelf het liefst een site in Firefox. Als je 'n site maakt in Firefox, Opera, Safari, Google Chrome of Edge, is er 'n hele grote kans dat hij in alle browsers werkt. Ik geef de voorkeur aan Firefox, omdat het de enige grote browser is die niet bij een bedrijf hoort dat vooral op je centen of je data uit is.
Google Chrome wordt ook door veel mensen gebruikt, maar ik heb dus wat moeite met hoe Google je hele surfgedrag, je schoenmaat en de kleur van je onderbroek vastlegt. Daarom gebruik ik Google Chrome zelf alleen om in te testen.
-
Het allereerste dat je moet invoeren, is het doctype, vóór welke andere code dan ook. Een lay-out met een missend of onvolledig doctype ziet er totaal anders uit dan een lay-out met een geldig doctype. Wát er anders is, verschilt ook nog 'ns tussen de diverse browsers. Als je klaar bent en dan nog 'ns 'n doctype gaat invoeren, weet je vrijwel zeker dat je van voren af aan kunt beginnen met de lay-out.
Geldige doctypes vind je op www.w3.org/QA/2002/04/valid-dtd-list.
Gebruik het volledige doctype, inclusief de url, anders werkt het niet goed.
-
Gebruik een 'strict' doctype of het doctype voor html5. Deze zijn bedoeld voor nieuwe sites. Het transitional doctype is bedoeld voor al bestaande sites, niet voor nieuwe. Het transitional doctype staat talloze tags toe, die in html5 zijn verboden. Deze tags worden al zo'n tien jaar afgeraden. Het transitional doctype is echt alleen bedoeld om de puinhoop van vroeger, toen niet volgens standaarden werd gewerkt, enigszins te herstellen.
Het strict doctype staat verouderde tags niet toe. Daardoor kan met 'n strict doctype, of het nu html of xhtml is, probleemloos worden overgestapt naar html5. Met een transitional doctype en het gebruik van afgekeurde tags kun je niet overstappen naar html5. Je moet dan eerst alle verouderde tags verwijderen, wat echt ontzettend veel werk kan zijn.
- Als tweede voer je de charset in. Het beste kun je utf-8 nemen. Als je later van charset verandert, loop je 'n grote kans dat je alle aparte tekens als letters met accenten weer opnieuw moet gaan invoeren.
- Test vanaf het allereerste begin in zoveel mogelijk verschillende browsers in 'n aantal resoluties (schermgroottes). Onder het kopje Getest in kun je in deze uitleg vinden, waar ikzelf op test. Ook van Internet Explorer kun je meerdere versies naast elkaar draaien. Je kunt daarvoor zoeken op internet en op de pagina met links staan onder de kopjes Gereedschap → Meerdere versies van Internet Explorer draaien en Gereedschap → Weergave testen 'n aantal links die daar ook bij kunnen helpen.
- Voor alle voorbeelden geldt: breng veranderingen stapsgewijs aan. Als je bijvoorbeeld foto's wilt laten weergeven, begin dan met het alleen veranderen van de namen van de foto's, zodat je eigen foto's worden weergegeven. Maakt niet uit als de maten niet kloppen en de teksten fout zijn. Als dat werkt, ga dan bijvoorbeeld de maten aanpassen. Dan de teksten. En controleer steeds, of alles nog goed werkt.
-
Als het om een lay-out of iets dergelijks gaat: zorg eerst dat header, kolommen, footer, menu, en dergelijke staan en bewegen, zoals je wilt, en ga dan pas details binnen die blokken invullen. In eerste instantie gebruik je dus bijvoorbeeld 'n leeg blok, voor waar uiteindelijk het menu komt te staan.
Als je begint met allerlei details, is er 'n heel grote kans dat die de werking van de blokken gaan verstoren. Bouw eerst het huis, en ga dan pas de kamers inrichten. Als de blokken eenmaal werken, zoals je wilt, zul je het gelijk merken, als 'n toegevoegd detail als tekst of 'n afbeelding iets gaat storen. Daarvoor moet je natuurlijk wel regelmatig controleren in verschillende browsers, of alles nog wel goed werkt.
Je kunt de blokken tijdens het aanpassen opvullen met bijvoorbeeld <br>1<br>2<br>3 enz., tot ze de juiste hoogte hebben. Het is handig om aan het einde even iets toe te voegen als 'laatste', zodat je zeker weet dat er niet ongemerkt drie regels onderaan naar 't virtuele walhalla zijn verhuisd.
Om de breedte te vullen, kun je het best 'n kort woord als 'huis' duizend keer of zo herhalen. Ook hier is het handig, om aan 't einde (en hier ook aan 't begin) 'n herkenningsteken te maken, zodat je zeker weet dat je de hele tekst ziet.
- Zolang je in grotere dingen zoals 'n lay-out aan 't wijzigen bent, zou ik je aanraden de verschillende delen een achtergrondkleur te geven. Je ziet dan goed, waar 'n deel precies staat.
- Als je instellingen verandert in de style, verander er dan maar één, hooguit twee tegelijk. Als je er zeventien tegelijk verandert, moet je niet verbaasd zijn, als je niet weet, wat er is gebeurd. En als je 't niet meer terug kunt draaien.
- Marges, padding en border worden bij de hoogte en breedte van de inhoud opgeteld. Hier worden vaak fouten mee gemaakt. Als je bijvoorbeeld in een lay-out 'n border toevoegt aan een van de 'hoofdvakken' (header, footer, kolommen), dan wordt deze er dus bij opgeteld. Bij 'n border van 2 px rondom de linkerkolom wordt deze dus plotseling 4 px breder (2 aan beide kanten), en 4 px hoger. Zoiets kan je hele lay-out verstoren, omdat iets net te breed of te hoog wordt. Je moet dan elders iets 4 px kleiner maken. Dat zal vaak zo zijn: als je één maat verandert, zul je vaak ook 'n andere moeten aanpassen.
- In plaats van px kun je ook andere maten gebruiken, met name em. Voordeel van em is dat een lettergrootte, regelhoogte, en dergelijke in em ook in Internet Explorer kan worden veranderd (andere browsers hebben meer mogelijkheden op dit gebied). Nadeel is dat het de lay-out sneller kan verstoren dan bijvoorbeeld px. Dit moet je gewoon van geval tot geval bekijken.
-
Valideren, valideren, valideren en dan voor 't slapen gaan nog 'ns valideren.
Valiwie???
Valideren is het controleren van je (x)html en css op 'n hele serie fouten. Computers zijn daar vaak veel beter in dan mensen. Als je 300 keer <h2> hebt gebruikt en 299 keer </h2> vindt 'n computer die ene missende </h> zonder enig probleem. Jij ook wel, maar daarna ben je misschien wel aan vakantie toe.
Je kunt je css en (x)html zowel valideren, als 't online staat, als wanneer 't nog in je computer staat.
(x)html kun je valideren op: validator.w3.org
css kun je valideren op: jigsaw.w3.org/css-validator
Valideren kan helpen om gekmakende fouten te vinden. Valide code garandeert ook dat de weergave in verschillende browsers (vrijwel) hetzelfde is. En valide code is over twintig jaar ook nog te bekijken.
Toegankelijkheid en zoekmachines
Het eerste deel van deze tekst is voor alle voorbeelden hetzelfde. Eventueel specifiek voor dit voorbeeld geldende dingen staan verderop onder het kopje Specifiek voor dit voorbeeld.
Toegankelijkheid (accessibility in het Engels) is belangrijk voor bijvoorbeeld blinden die een spraakbrowser gebruiken, of voor motorisch gehandicapte mensen die moeite hebben met het bedienen van een muis. Een spider van een zoekmachine (dat is het programmaatje wat de site indexeert voor de zoekmachine) is te vergelijken met een blinde. Als je je site goed toegankelijk maakt voor gehandicapten, is dat dus gelijk goed voor een hogere plaats in een zoekmachine. Dus als je 't niet uit sociale motieven wilt doen, kun je 't uit egoïstische motieven doen.
(Op die plaats in de zoekmachine heb je maar beperkt invloed. De toegankelijkheid van je site is maar één van de factoren, maar zeker niet onbelangrijk.)
Als je bij het maken van je site al rekening houdt met toegankelijkheid, is dat nauwelijks extra werk. 't Is ongeveer te vergelijken met inbraakbescherming: doe dat bij 'n nieuw huis en 't is nauwelijks extra werk, doe 't bij 'n bestaand huis en 't is al snel 'n enorme klus.
Enkele tips die helpen bij toegankelijkheid:
-
Gebruik altijd een alt-beschrijving bij een afbeelding. De alt-tekst is wat wordt gebruikt, als afbeeldingen niet kunnen worden gezien (dat geldt dus ook voor zoekmachines). Als je iets wilt laten zien, als je over de afbeelding hovert, gebruik daar dan het title-attribuut voor, niet de alt-beschrijving.
Als een afbeelding alleen maar voor de sier wordt gebruikt, zet je daarbij
alt=""
, om aan te geven dat de afbeelding niet belangrijk is voor het begrijpen van de tekst of zo. - Gebruik bij een link een title, waarin je omschrijft, waar de link naartoe leidt.
-
Accesskeys (sneltoetsen) kun je beter niet gebruiken, deze geven te veel problemen omdat ze vaak dubbelop zijn met sneltoetsen voor de browser of andere al gebruikte sneltoetsen. Bovendien is voor de gebruiker meestal niet duidelijk, welke toetsen het zijn.
In de komende html5 waren ze eerst niet toegestaan, maar inmiddels lijkt het erop dat ze toch worden toegestaan, maar op 'n andere manier dan in html 4.01.
Op zichzelf zijn accesskeys een heel goed idee. Maar helaas zijn ze ook in html5 volstrekt onvoldoende gedefinieerd.
Er is nog steeds geen standaard voor de meest gebruikelijke accesskeys, zoals Zoek of Home.
Er is nog steeds niet vastgelegd hoe accesskeys zichtbaar gemaakt kunnen worden. Voor de makers van browsers zou dit 'n relatief kleine moeite zijn, voor de makers van 'n site is het bergen extra werk.
Voor mij redenen om accesskeys helemaal niet te gebruiken. Ik kan me wel voorstellen dat ze op sites die gericht zijn op 'n specifieke groep gebruikers nog enig nut kunnen hebben, maar voor algemene sites zou ik zeggen: niet gebruiken.
- Met behulp van de Tab-toets (of op 'n soortgelijke manier) kun je in de meeste browsers door links, invoervelden, en dergelijke lopen. Elke tab brengt je één link, invoerveld, en dergelijke verder, Shift+Tab één plaats terug. Met behulp van
tabindex
kun je de volgorde aangeven waarin de Tab-toets werkt. Zondertabindex
wordt de volgorde van de html aangehouden, maar soms is een andere volgorde logischer. -
In het verleden werd vaak aangeraden de volgorde van de code aan te passen. Een menu bijvoorbeeld kon in de html onderaan worden gezet, terwijl het op het scherm met behulp van css bovenaan werd gezet. Inmiddels zijn screenreaders en dergelijke zo verbeterd, dat dit niet meer wordt aangeraden. De volgorde in de html kan tegenwoordig beter hetzelfde zijn als op het scherm, omdat het anders juist verwarrend kan werken.
Een andere mogelijkheid is een zogenaamde skip-link: een link die je buiten het scherm parkeert met behulp van css, zodat hij normaal genomen niet te zien is. Zo'n link is wel zichtbaar in speciale programma's zoals spraakbrowsers. Die link staat boven menu, header, en dergelijke en linkt naar de inhoud van de pagina, zodat mensen met één toetsaanslag naar de eigenlijke inhoud van de pagina kunnen gaan.
Een skip-link is ook nuttig voor gebruikers van de Tab-toets. Zodra de normaal genomen onzichtbare link door het indrukken van de Tab-toets focus krijgt, kun je hem op het scherm plaatsen, waardoor hij zichtbaar wordt. Bij een volgende tab wordt hij dan weer buiten het scherm geplaatst en is dus niet meer zichtbaar.
-
Van oorsprong was html een taal om wetenschappelijke documenten weer te geven, pas later is hij gebruikt voor lay-out. Maar daar is hij dus eigenlijk nooit voor bedoeld geweest. Het gebruiken van html voor lay-out leidt tot enorme problemen voor gehandicapten en tot een lage plaats in zoekmachines.
De html hoort alleen inhoud te bevatten, lay-out doe je met behulp van css. Die css moet in een extern stylesheet staan of, als hij alleen voor één bepaalde pagina van toepassing is, in de head van die pagina. Zoekmachines zijn ook niet dol op een oerwoud van inline-stijlen (dat zijn stijlen in de tag zelf:
<div style="...">
.) -
Breng een logische structuur aan in je document. Gebruik een <h1> voor de belangrijkste kop, een <h2> voor een subkop, enz. Spraakbrowsers en dergelijke kunnen van kop naar kop springen. En een zoekmachine gaat ervan uit dat <h1> belangrijke tekst bevat.
Dit geldt voor al dit soort structuurbepalende tags.
Als een <h1> te grote letters geeft, maak daar dan met behulp van je css 'n kleinere letter van, maar blijf die <h1> gewoon gebruiken. Op dezelfde manier kun je al dit soort dingen oplossen.
- Een table is fantastisch, maar alleen als die wordt gebruikt om een echte tabel weer te geven, niet als hij voor opmaak wordt misbruikt. In het verleden is dat op grote schaal gebeurd bij gebrek aan andere mogelijkheden. Een tabel is, als je niet heel erg goed oplet, volstrekt ontoegankelijk voor gehandicapten en zoekmachines. Het lezen van een tabel is ongeveer te vergelijken met het lezen van een krant van links naar rechts: niet per kolom, maar per regel. Dat gaat dus alleen maar goed bij een echte tabel zoals een spreadsheet. In alle andere gevallen garandeert 'n tabel 'n lagere plaats in een zoekmachine.
-
Frames horen bij een volstrekt verouderde techniek, die heel veel nadelen met zich meebrengt. <iframe>'s hebben voor een deel dezelfde nadelen. Eén van die nadelen is dat de verschillende frames voor zoekmachines, schermlezers, en dergelijke als los zand aan elkaar hangen, omdat ze los van elkaar worden weergegeven. Ze staan wel naast elkaar op het scherm, maar er zit intern geen verband tussen.
Als je 'n stuk code vaker wilt gebruiken, zoals 'n menu dat op elke pagina hetzelfde is, voeg dat dan in met PHP of SSI (Server Side Includes). Dan wordt de pagina niet pas in de browser, maar al op de server samengesteld. Hierdoor zien zoekmachines, schermlezers, en dergelijke één pagina, net zoals wanneer je maar één pagina met html zou hebben geschreven.
- Geef de taal van het document aan, en bij woorden en dergelijke die afwijken van die taal de afwijkende taal met behulp van
lang=".."
. Ik doe dat op mijn eigen site maar af en toe, omdat de tekst (en vooral de code) een mengsel is van Engels, Nederlands en eigengemaakte namen. Dit soort teksten is gewoon niet goed in te delen in een taal. Maar bij enigszins 'normale' teksten hoor je een taalwisseling aan te geven. - Gebruik de tag <abbr> bij afkortingen. Doe dat de eerste keer op een pagina samen met de title-eigenschap:
<abbr title="en dergelijke">e.d.</abbr>
. Daarna kun je op dezelfde pagina volstaan met<abbr>e.d.</abbr>
. Doe je dit niet, dan is er 'n grote kans dat 'n spraakbrowser 'e.d.' uit gaat spreken als 'Ed', en 'n zoekmachine kan er ook geen chocola van maken. -
De spider van 'n zoekmachine, spraakbrowsers, en dergelijke kunnen geen plaatjes 'lezen'. Het is soms verbazingwekkend om te zien hoe veel, of eigenlijk: hoe weinig tekst er overblijft op een pagina, als de plaatjes worden weggehaald. Hetzelfde geldt voor die fantastisch mooie flash-pagina's, als daarbij geen voorzieningen voor dit soort programma's zijn aangebracht.
Op Linux kun je met Lynx kijken, hoe je pagina eruitziet zonder plaatjes en dergelijke, als echt alleen de tekst overblijft. Een installatie-programma voor Lynx op Windows is te vinden op csant.info/lynx.
Ook kun je in Windows het gratis programma WebbIE installeren. WebbIE laat de pagina zien, zoals een spraakbrowser en dergelijke hem zien. WebbIE is te downloaden vanaf www.webbie.org.uk.
Ten slotte kun je je pagina nog online laten controleren op 'n behoorlijk aantal sites. Ik noem er hier enkele. Helaas zijn ze bijna allemaal Engelstalig.
toptal.com Laat zien hoe een kleurenblinde de site ziet.
wave.webaim.org Deze laat grafisch zien hoe de toegankelijkheid is.
Specifiek voor dit voorbeeld
-
Zonder css wordt de site in de volgorde van de html op het scherm gezet: header, eerste kolom, tweede kolom, derde kolom, menu. Dit is ook zoals de meeste spraakbrowsers en dergelijke het zullen zien.
Omdat de volgorde wat afwijkt, van wat op het scherm wordt getoond (behalve in browservensters smaller dan 600 px), zijn bij dit voorbeeld WAI-ARIA-codes gebruikt om de toegankelijkheid te vergroten. Meer daarover kun je lezen bij Semantische elementen en WAI-ARIA.
-
Het menu is in een ongeordende lijst <ul> gezet, omdat veel spraakbrowsers en dergelijke een menu daarbinnen herkennen, zodat de gebruiker het in één keer kan passeren en naar de echte inhoud van de pagina kan gaan.
In de toekomst zullen spraakbrowsers en dergelijke een menu in een <nav> ook gaan herkennen, maar dat kan nog jaren duren. Bovendien is een menu in een <ul> heel makkelijk op te maken.
Getest in
Laatst gecontroleerd op 4 april 2013.
Onder dit kopje staat alleen maar, hoe en waarin is getest. Eventuele problemen, ook die met betrekking tot zoomen en lettergroottes, staan hieronder bij Bekende problemen. Het is belangrijk dat te lezen, want uit een test kan ook prima blijken dat iets totaal niet werkt!
Eventuele opmerkingen over de toegankelijkheid specifiek voor dit voorbeeld staan onderaan Toegankelijkheid en zoekmachines onder het kopje Specifiek voor dit voorbeeld.
Dit voorbeeld is getest op de volgende systemen:
- Windows XP:
Firefox, Opera en Google Chrome in een resolutie van 1440x900.
Internet Explorer 8 in de resoluties 800x600, 1024x768, 1280x1024 en 1440x900. - Windows 7:
Firefox, Opera, Google Chrome en Internet Explorer 9 in de resoluties 800x600, 1024x768 en 1280x1024. - Windows 8:
Firefox, Opera, Google Chrome en Internet Explorer 10 (bureaublad-versie en startscherm-versie) in de resoluties 800x600, 1024x768 en 1366x768. - OS X:
Firefox, Opera, Safari en Google Chrome in de resolutie 1024x768. - Linux:
Firefox, Opera en Google Chrome in de resoluties 800x600, 1024x768 en 1280x1024. - iPad met iOS 6.1 in een resolutie van 1024x768 (MC979NF):
Safari (portret en landschap).
Opera Mini (portret en landschap).
Chrome for IOS (portret en landschap). - Android 4.0.3 in een resolutie van 1024x768 (CRESTA CTP888):
Android browser, Opera Mobile, Firefox en Chrome voor mobiel (alles portret en landschap). - Android 2.3.6 in een resolutie van 320x240 (Samsung Galaxy Y GT-S5360):
Android browser (portret en landschap).
Opera Mobile (éénkolomsstand aan/uit, portret en landschap).
Opera Mini (éénkolomsstand aan/uit, portret en landschap). Deze browser is een apart geval. De opgevraagde site wordt gedownload via de servers van Opera, waarbij het in zo'n klein venster normaal is dat (het grootste deel van) de lay-out wordt verwijderd. Daarom wordt bij deze browser alleen gekeken, of er geen content (tekst en dergelijke) verloren gaat.
Er is steeds getest met de laatste versie van de browsers op de hierboven genoemde controledatum, omdat ik geen zin heb om rekening te houden met mensen die met zwaar verouderde browsers surfen. Dat is trouwens vragen om ellende, want updates van browsers hebben heel vaak met beveiligingsproblemen te maken.
In resoluties groter dan 800x600 is ook in- en uitzoomen en - voor zover de browser dat kan - een kleinere en grotere letter getest. Er is ingezoomd en vergroot tot zover de browser kan, maar niet verder dan tot 200%.
Er is getest met behulp van muis en toetsenbord, behalve op de iPad en Android, waar een touchscreen is gebruikt. Op Windows 8 is zowel met een touchscreen als met een combinatie van toetsenbord en touchpad getest.
Naast deze 'gewone' browsers is ook getest in Lynx, WebbIE, NVDA en Fangs Screen Reader Emulator. Lynx is een browser die alleen tekst laat zien en geen css gebruikt. WebbIE is een browser die gericht is op mensen met een handicap. NVDA is een screenreader, zoals die door blinden wordt gebruikt. Fangs Screen Reader Emulator is een extensie bij Firefox, die de pagina laat zien, zoals een screenreader hem ziet.
Als het voorbeeld in deze vier programma's toegankelijk is, zou het in principe toegankelijk moeten zijn in alle aangepaste browsers en dergelijke. En dus ook voor zoekmachines, want een zoekmachine is redelijk vergelijkbaar met een blinde. Eventuele opmerkingen over de toegankelijkheid specifiek voor dit voorbeeld staan onderaan Toegankelijkheid en zoekmachines onder het kopje Specifiek voor dit voorbeeld.
Alleen op de hierboven genoemde systemen en browsers is getest. Er is dus niet getest op bijvoorbeeld 'n Blackberry. De kans is (heel erg) groot dat dit voorbeeld niet (volledig) werkt op niet-geteste systemen en apparaten. Om het wel (volledig) werkend te krijgen, zul je vaak (kleine) wijzigingen en/of (kleine) aanvullingen moeten aanbrengen, bijvoorbeeld met JavaScript.
Er is ook geen enkele garantie dat iets werkt in een andere tablet of smartphone dan hierboven genoemd, omdat fabrikanten in principe de software kunnen veranderen. Dit is anders dan op de desktop, waar browsers altijd (vrijwel) hetzelfde werken, zelfs op verschillende besturingssystemen. Iets wat in Android browser werkt, zal in de regel overal werken in die browser, maar een garantie is er niet. De enige garantie is het daadwerkelijk testen op een fysiek apparaat. En aangezien er duizenden mobiele apparaten zijn, is daar eigenlijk geen beginnen aan.
De html is gevalideerd met de validator van w3c, de css ook. Als om een of andere reden niet volledig gevalideerd kon worden, wordt dat bij Bekende problemen vermeld.
Nieuwe browsers test ik pas, als ze uit het bèta-stadium zijn, omdat er anders 'n redelijke kans is dat ik 'n bug zit te omzeilen, die voor de uiteindelijke versie nog gerepareerd wordt. Dit voorbeeld is alleen getest in de hierboven met name genoemde browsers. Vragen over niet-geteste browsers kan ik niet beantwoorden, en het melden van fouten in niet-geteste browsers heeft ook geen enkel nut. (Melden van fouten, problemen, enz. in wel geteste browsers: graag!)
Bekende problemen
Waarop en hoe is getest, kun je gelijk hierboven vinden bij Getest in.
Als je hieronder geen oplossing vindt voor een probleem dat met dit voorbeeld te maken heeft, kun je op het forum proberen een oplossing te vinden voor je probleem. Om forumspam te voorkomen, moet je je helaas wel registreren, voordat je op het forum een probleem kunt aankaarten.
In eerste instantie lijkt dit een ontmoedigend lange lijst met problemen. De meeste problemen zijn echter kleine afwijkingen van de lay-out, of kunnen simpel worden ontlopen. De lijst is voornamelijk zo lang, omdat ik probeer zo volledig mogelijk te zijn.
Links binnen de pagina (ankers) in vensters breder dan 810 px
Kort samengevat: deze lay-out is minder geschikt voor pagina's die ankers bevatten. Het uitgebreidere verhaal:
Normaal genomen kun je met de Terug‑ en Vooruit-knop (de precieze naam hangt van de browser af) naar een vorige of (als die er al is) volgende pagina gaan. (Bij gebruik van een toetsenbord werken, afhankelijk van de browser, bepaalde toetscombinaties zoals alt+→ en alt+← precies hetzelfde.) Daarbij maakt het niet uit of die vorige of volgende pagina binnen of buiten de huidige site staat.
Op precies dezelfde manier kun je binnen een pagina terug‑ en vooruitgaan. Als je bijvoorbeeld bovenaan de pagina op een link klikt naar een plaats verderop in dezelfde pagina ('n anker), kun je normaal genomen met iets als alt+← weer terug, naar waar je geklikt hebt.
Omdat in dit geval de oranje kolom verreweg het hoogste is, zullen dit soort ankers (vrijwel) alleen binnen de oranje kolom voorkomen.
Helaas werken bij deze constructie de genoemde toetsen niet in alle browsers binnen de pagina zelf: je gaat niet altijd terug of vooruit naar de vorige of volgende positie binnen de pagina, maar naar een compleet andere vorige of volgende pagina.
Als je position: absolute;
of overflow: auto;
weghaalt bij div#wrapper
, werken de toetsen, zoals ze normaal genomen werken: je gaat ook binnen de pagina terug of vooruit naar een vorige of volgende positie. Het weghalen van één van deze twee eigenschappen is al voldoende. Alleen schiet dat ook niet echt op, omdat je dan deze lay-out niet kunt maken.
Dit is ook de reden dat dit probleem alleen speelt in browservensters breder dan 810 px: in smallere vensters worden deze drie eigenschappen niet gebruikt.
Deze lay-out is dus niet echt geschikt voor teksten, waarbinnen je veel heen en weer moet gaan, bijvoorbeeld om voetnoten onderaan de pagina te bekijken. En ook niet voor pagina's met (veel) ankers.
Om misverstanden te voorkomen: behalve in Opera Mini gaat het hier alleen om links binnen div#wrapper
. Links vanuit header, menu, en dergelijke naar div#wrapper
werken volledig normaal. Ook links naar en van andere pagina's werken op de normale manier, inclusief de genoemde toetscombinaties.
Alleen in Opera Mini (Android en iOS) leiden álle links naar een anker binnen div#wrapper
naar ogenschijnlijk volledig willekeurige plaatsen. Overigens werkt terug‑ of vooruitgaan binnen dezelfde pagina helemaal nooit in deze browser: je gaat altijd terug of vooruit naar de vorige of volgende pagina.
Ditzelfde probleem speelt in de roze en donkergroene kolom, maar daarin zullen normaal genomen geen ankers voorkomen.
In een toenemend aantal browsers werken deze toetsen inmiddels wel, zoals ze horen te werken: Safari (overal), Google Chrome (overal), Opera Mobile (Android 4.0.3), Android Browser (Android 2.3.6 en 4.0.3), Firefox (Windows 8 en Android 4.0.3). Je gaat terug naar de plaats waar je vandaan kwam, ook binnen de pagina. (Bij Safari, Google Chrome en Firefox was dit eerst niet zo, dus er is hoop dat ze ooit in alle browsers goed werken.)
Alle niet-mobiele browsers in vensters breder dan 810 px
Als het goed is, scrollen in deze browsers header en menu niet mee met de rest van de pagina, maar blijven ze vast op het scherm staan.
Als er een verticale scrollbalk in het venster van de browser staat, kun je scrollen binnen het element waar die scrollbalk bij hoort. Vaak zal dat de hele pagina zijn. In dit voorbeeld is het div#wrapper
, waarbinnen een aantal kolommen staat.
Dat scrollen doen de meeste mensen met het wieltje van de muis of door in de scrollbalk te klikken of te slepen. Dit werkt allemaal zoals het normaal werkt.
Scrollen kan echter ook met PgDn of Spatiebalk, PgUp of Shift+Spatiebalk, ↓ of ↑. Met de eerste twee ga je 'n venster omlaag, met de middelste twee 'n venster omhoog, en met de pijltjes één regel omlaag of omhoog.
Omdat de kolommen binnen een absoluut gepositioneerde div staan, werken deze toetsen niet zonder meer. Je moet eerst even binnen div#wrapper
klikken. Mensen die deze toetsen gebruiken, zullen dit echter weten, omdat je dit heel vaak tegenkomt. Dus 'n echt groot probleem zal dit niet zijn.
Bij 'n touchscreen speelt dit uiteraard niet, omdat je per definitie het scherm aan moet raken om te kunnen scrollen.
Internet Explorer 8
- Als het niet lijkt, op wat je op de site ziet, geen achtergrondkleuren heeft, alles zomaar ergens neergesmeten lijkt te zijn, enz., heb je waarschijnlijk geen JavaScript aangebracht voor deze browsers, of JavaScript staat uit. Bij Media queries en Internet Explorer 8 en Touchscreens herkennen met behulp van modernizr staat hier meer over.
-
Internet Explorer 8 heeft geen ronde hoeken aan boven- en onderkant van het menu, omdat het
border-radius
niet kent. Ik heb enkele scripts en dergelijke geprobeerd die ronde hoeken mogelijk maken in deze browser, maar die werkten niet. Bovendien gaven ze soms problemen, zoals het verdwijnen van álle lay-out in het menu. Omdat de broncode van deze browser geheim is, zijn altijd werkende scripts eigenlijk niet te maken.Op de pagina met links onder CSS → Bugs en hacks → Dingen mogelijk maken specifiek voor Internet Explorer vind je links naar JavaScript en zo, waarmee je zelf nog kunt gaan spelen in de hoop ronde hoeken te kunnen maken. Persoonlijk vind ik het de moeite niet waard. Het ziet er goed uit, alleen heeft het menu rechte hoeken.
Internet Explorer 9 herkent (eindelijk) gewoon
border-radius
. - In browservensters smaller dan 810 px hoort achter de knoppen van het menu een gradiënt te zitten: links en rechts zwart, in het midden iets grijzer. Zo'n gradiënt met drie kleuren is niet te maken in Internet Explorer 8, je zou daar een afbeelding voor moeten gebruiken. Daarom is in deze browser de achtergrond van de knoppen gewoon effen zwart.
-
Bij uitzoomen (verkleinen) springt de pagina steeds weer terug naar boven, als er omlaag wordt gescrold.
Dit zijn bijwerkingen van het JavaScript css3-mediaqueries.js. Bij het JavaScript respond.js gebeurde dit niet. (Ik gebruik css3-mediaqueries.js omdat op de site respond.js niet werkt, en ik probeer het 'n beetje hetzelfde te houden, anders wordt het al snel één grote bende.)
Dit komt trouwens niet, doordat dit script zo slecht is, maar doordat Internet Explorer 8 barstensvol bugs en afwijkingen zit. En omdat de broncode ook nog 'ns geheim is, is het vrijwel onmogelijk die fouten te omzeilen.
Internet Explorer 8 en 9
In de eerste (oranje) en derde (donkergroene) kolom staat in een breder browservenster de inhoud van deze kolommen zelf soms ook weer in kolommen. Omdat Internet Explorer 8 en 9 css-kolommen (column-...
) niet kennen, staat in deze browsers alles altijd in één kolom. Internet Explorer 10 kent wel css-kolommen.
Als je kolommen echt belangrijk vindt, kun je op de pagina met links mogelijk een oplossing vinden onder CSS → Bugs en hacks → Dingen mogelijk maken specifiek voor Internet Explorer of onder CSS → Bugs en hacks → Niet-ondersteunde elementen, eigenschappen, enz. mogelijk maken.
Opera Mini op Android 2.3.6
- Met de éénkolomsstand aan negeert Opera Mini de minimumhoogte van de links, waardoor het wat lastig is deze met de vingers te bedienen. Met de éénkolomsstand uit wordt de minimumhoogte wel aangehouden.
- In browservensters smaller dan 600 px staat het menu onderaan de pagina. In de header verschijnt een link naar het menu. Omdat Opera Mini links niet onderstreept, is het iets minder duidelijk dat dit een link is. Opera Mini onderstreept links nooit, dit geldt dus ook voor eventuele andere links.
Opera Mini op de iPad
-
Opera Mini op de iPad lijkt ten onrechte niet te melden dat touch events worden herkend. In portretstand is dit geen probleem, omdat de weergave dan altijd zonder gebruik van absolute posities is.
Maar in landschapsstand is dit wel een groot probleem, omdat
div#wrapper
nu absoluut is gepositioneerd. Als je omlaag wilt scrollen, werkt dat niet. Tekst die onder het browservenster staat, wordt niet zichtbaar. De hele pagina scrolt weliswaar, maar er verschijnt geen nieuwe tekst. De hele pagina verdwijnt gewoon aan de bovenkant buiten het venster.Als de pagina wordt geopend in portretstand, gaat het goed. Als vervolgens wordt gedraaid naar landschapsstand, blijft het goed gaan. De weergave voor mobiele browsers blijft behouden. Pas als na het draaien de pagina wordt ververst, wordt de weergave voor desktopbrowsers gebruikt en gaat het mis.
Als de pagina wordt geopend in landschapsstand, is het net omgekeerd. Ook bij draaien naar portretstand blijft de weergave voor desktopbrowsers gebruikt worden, en scrolt dus de hele pagina van het scherm, zonder dat nieuwe tekst verschijnt. Pas als de pagina na draaien wordt ververst, wordt de weergave voor mobiele browsers gebruikt.
- De knoppen in het menu hebben geen ronde hoeken en de achtergrond is effen zwart. Om ronde hoeken en een gradiënt te krijgen, zou je gebruik moeten maken van afbeeldingen. Daar vind ik het niet belangrijk genoeg voor.
- In browservensters smaller dan 600 px staat het menu onderaan de pagina. In de header verschijnt een link naar het menu. Omdat Opera Mini links niet onderstreept, is het iets minder duidelijk dat dit een link is. Opera Mini onderstreept links nooit, dit geldt dus ook voor eventuele andere links.
Opera Mobile op Android 2.3.6 en 4.0.3
In browservensters smaller dan 600 px staat het menu onderaan de pagina. In de header verschijnt een link naar het menu. Omdat Opera Mobile links niet onderstreept, is het iets minder duidelijk dat dit een link is. Opera Mobile onderstreept links nooit, dit geldt dus ook voor eventuele andere links.
Firefox (alle versies)
Firefox kent column-span
niet. Hierdoor staan de kopregels in Firefox niet midden boven de tekst, maar links.


column-span
kennen.Zoomen
Op touchscreens werken in- en uitzoomen altijd hetzelfde, onderstaande geldt daarom alleen voor de desktop.
Firefox, Opera, Internet Explorer 8, 9 en 10 (bureaublad-versie) in Windows, OSX en Linux: in- en uitzoomen ziet er hetzelfde uit, als wanneer de pagina zou worden getoond in een smaller of breder browservenster.
Internet Explorer 10 (startscherm-versie) in Windows 8: uitzoomen (verkleinen) werkt niet. Bij uitzoomen blijft de lay-out hetzelfde, alles wordt alleen breder en zo.
Safari en Google Chrome in OSX, Google Chrome in Windows en Linux: bij in- en uitzoomen blijft de lay-out hetzelfde, alleen de breedte en zo verandert.
Mobiele browsers en fixed of absolute positie
Het gaat hier om problemen die zich niet voordoen, omdat geen fixed of absolute positie wordt gebruikt bij mobiele browsers. Maar als dat wel zou worden gebruikt, dan zouden onderstaande problemen zich voordoen. Die problemen zijn precies de reden dat geprobeerd wordt een absolute of fixed positie bij mobiele browsers te voorkomen.
Omdat er maar een beperkt aantal browsers is getest, zullen er waarschijnlijk nog (veel) meer problemen zijn die hier niet worden beschreven, omdat er niet op is getest.
Opera Mobile op Android 4.0.3 in landschapsstand (1024x768): omdat in portretstand de hele pagina scrolt, speelt in portretstand onderstaande probleem niet.
Bij opening van de pagina staat alles goed. Ook scrollen levert geen problemen op: de hele inhoud van de pagina is zichtbaar. Bij het menu gaat het echter mis. Als het menu fixed is gepositioneerd, zou het in principe niet moeten scrollen, maar altijd zichtbaar moeten zijn. Soms is dat zo, maar soms verdwijnt het menu gewoon helemaal, of verdwijnt een aantal knoppen.
Opera Mini op de iPad in landschapsstand (1024x768): in portretstand speelt dit probleem niet, want daar scrolt de hele pagina mee.
Bij openen van de pagina ziet alles eruit zoals het hoort: header bovenaan, menu links en daarnaast twee kolommen. Maar bij scrollen blijkt álles mee te scrollen, alsof de pagina 'n afbeelding is. Bovendien verschijnt er geen nieuwe tekst: je ziet alleen, wat bij opening al zichtbaar was.
Safari en Google Chrome op de iPad, Google Chrome, Android browser, Firefox en Opera Mobiel op Android 4.0.3, allemaal in landschapsstand (1024x768): bij inzoomen (vergroten) verdwijnen header en menu buiten het venster. Als door scrollen de header of menu weer terugkomen op het venster, blijven die soms weer staan, soms niet. Soms wordt het menu over de tekst in de eerste (oranje) kolom gezet. Met scrollen is alles wel zichtbaar te krijgen, maar beter is om gewoon niet fixed of absoluut te positioneren.
Android browser in landschapsstand op Android 4.0.3: in landschapsstand werkt er geen enkele link naar een anker binnen de pagina, ook niet vanuit de header of het menu. Links naar andere pagina's werken wel normaal. Zonder position: absolute;
bij div#wrapper
werken de ankers wel, maar dan is de lay-out niet meer goed. Dit is een ernstig probleem, dat het gebruik van ankers feitelijk onmogelijk maakt. Door geen absolute of fixed positie te gebruiken in deze browser, wordt dit probleem voorkomen.
Wijzigingen
Alleen grotere wijzigingen worden hier vermeld, geen dingen als een link die is geüpdatet.
:
Nieuw opgenomen.