10 grundläggande lektioner i CSS
Postad: 7 juni 2009 | CSS-guider | 5 CommentsVälkommen till femte lektionen!
En hemsida är ganska så intetsägande utan bilder och färger. Vi ska nu gå igenom hur man gör för att sätta färg på bakgrunden, och lägga in en bakgrundsbild.
Bakgrundsfärg
När vi hör ordet bakgrund så är det oftast bakgrunden för själva sidan vi i första hand tänker på, det vill säga body. Men en bakgrundfärg kan också anges för andra element, exempelvis olika divblock och tabeller. I guiden om fonter lade vi också till en bakgrundsfärg på texten. Så bakgrund kan betyda mycket.
För att ge en färgad bakgrund åt själva dokumentets body så är css-syntaxen följande:
body {background-color: #000;}
Du kanske använder tabeller till data och vill skifta färg i tabellcellerna? Kika då på följande märkningar. Man kan både använda class-attribut som globala värden – allt efter tycke och smak. Här har hela tabellen ett globalt värde: svart bakgrund och vit textfärg.
table {background-color: #000; color:#fff;}
Nu ska vi sätta färg på tabellcellerna. Värdet är globalt.
td {background-color: #ccc; color:#333;}
Vill man göra det lite mer avancerat då är class-attributet en bra hjälp. Först måste du ange en class selector i din stilmall. Observera att detta inte blir ett globalt värde.
Css-syntax:
.td1 {background-color: #000; color:#fff;}
HTML-kod:
<table><tr><td class="td1">cellen får nu en svart bakgrundsfärg och vit text</td></tr></table>
Bakgrundsbild
Vill du använda en bakgrundsbild på din webbsida ser css-syntax ut så här.
body {background-image: url(din_bild.jpg);}
Tillsammans med bakgrundsfärg och textfärg:
body {background-color: #000; color:#fff;background-image: url(din_bild.jpg);}
Bakgrundsbild i en tabell:
table {background-image: url(din_bild.jpg);}
Tillsammans med bakgrundsfärg och textfärg:
table {background-color: #000; color:#fff;background-image: url(din_bild.jpg);}
Bakgrundbild, bakgrundsfärg, och textfärg i tabellcellerna.
Globalt värde:
td {background-color: #000; color:#fff;background-image: url(din_bild.jpg);}
Som class-attribut:
.td1 {background-color: #000; color:#fff;background-image: url(din_bild.jpg);}
HTML-koden:
<table><tr><td class="td1">cellen får nu en svart bakgrundsfärg, vit text, samt en bakgrundsbild</td></tr></table>
Vill du lägga in en bakgrundsbild i ett div-block?
#(vald ID-selektor) {background-image: url(din_bild.jpg);}
Position, repeat, attachment
Så här långt har vi alltså lagt in en bakgrundsbild, nu ska vi dels positionera bilden, dels bestämma om den ska upprepas samt hur den i så fall ska upprepas, och dels om bilden ska vara fixerad (icke-scrollbar med layouten) eller inte.
Positionera en bild
Deafultläget (grundläget) för en webbläsare är vänsterställt | vänster hörn | högst upp. Det innebär att om man inte formaterar en bild (eller text) så kommer den att lägga sig allra längst upp i det vänstra hörnet.
Med css har du alltså själv möjlighet att bestämma utgångsläget för placeringen av din bild.
Vi ska kika på vilka alternativ det finns och hur dessa fungerar.
Det finns fem olika koordinater: top, bottom, left, right och center. Du kan även välja att positionera bilden med följande enheter: centimeter (cm), pixlar (px), procent (%) och em.
Utgångsläget är alltid från det vänstra övre hörnet – top left.
Css-syntax utan enheter:
background-position:top left;
Vänstra övre hörnetbackground-position:top right;
Högra övre hörnetbackground-position:center center;
Mittenbackground-position:bottom left;
Vänstra nedre hörnetbackground-position:bottom right;
Högra nedre hörnet
Css-syntax med procentenheter:
background-position:0% 0%;
Vänstra övre hörnetbackground-position:50% 50%;
Mittenbackground-position:100% 100%;
Högra nedre hörnet
Css-syntax med pixlar:
background-position:30px 30px;
30px avstånd från left + 30px avstånd från topbackground-position:10px 100px;
10px avstånd från left + 100px avstånd från top
Upprepa en bild – repeat
Används en bild som bakgrundsbild kan man behöva repetera bilden. Precis som i positioneringen kan man välja hur bilden ska repeteras, eller om den inte ska repeteras.
Css-syntax:
background-repeat:no-repeat;
– ingen upprepning (defaultläget vänstra övre hörnet)background-repeat:repeat;
– upprepas från left till right och top till bottombackground-repeat:repeat-x;
– upprepas endast horisontellt (vänster till höger)background-repeat:repeat-y;
– Upprepas vertikal/lodrätt (top till bottom)
Background attachment
Beroende på hur din bakgrundsbild ser ut kan man ibland behöva få bilden att vara fixerad, det vill säga den ska inte vara scrollbar. Det innebär att det bara är din layout som är rörlig och ligger ”ovanpå” bakgrunden.
Vill du däremot att bakgrunden ska scrollas tillsammans med din layout går det också bra. Css-syntaxen för båda alternativen:
Background-attachment:fixed;
– Bakgrundsbilden är låst och scrollar inteBackground-attachment:scroll;
– Bakgrundsbilden är inte låst och scrollar med layouten
Egenskaper för background (bakgrund)
background-color | anger bakgrundsfärgen på ett element |
background-image | ger en bakgrundsbild |
background-repeat | anger om bakgrunden ska repeteras med följande värden: repeat, no-repeat, repeat-x, repeat-y |
background-position | anger bakgrundsbildens position med följande värden: top, right, bottom, left, center |
background-attachment | anger om du vill att bakgrunden ska vara fixerad (statisk) eller ej med följande värden: scroll, fixed |
Egenskaperna för background kan användas som shorthand declarationgroup och ska då användas i denna ordning:
background-color | background-image | background-repeat | background-attachment | background-position
Css-koden här under ger följande värden: svart bakgrundsfärg, en bakgrundsbild som inte upprepas utan ligger låst i det vänstra övre hörnet.
body {background: #000 url(images/background-image.jpg) no-repeat fixed left top ;}
I lektion sex kommer vi att gå igenom egenskaperna för border.
Välkommen dit!