Kaskadkoppling & Semantik

Jag har just börjat ett nytt projekt, eller rättare sagt så har jag börjat med att avsluta någon annans projekt. Normalt så brukar inte detta vara ett problem, men denna organisation är inte särskilt organiserad, det var ett tag sedan jag arbetade som frilansare utanför en agentur, men kanske är det så är pleben arbetar.

CSS, är en webbsidas stylist, C:et står för ‘Cascading’ dvs. kaskadkoppling, så alla klasser däri borde följa och implementera varandra, men dessa CSS filer är runt 16,000 rader tillsammans, och specificerar varje element individuellt. Hur fan kan man arbeta så!

t.ex. deras kod:

.account #wrapper .my-account #content h3 {
	font-family: "BitstreamCooperBlack", 'cooper black';
	font-size: 150%;
	color: #444;
	margin: 10px 5px;	
}

.account #wrapper .my-account #content h4 {
	font-family: "BitstreamCooperBlack", 'cooper black';
	font-size: 120%;
	color: #444;
	margin: 10px 5px;	
}

.account #wrapper .my-login #content h3 {
	font-family: "BitstreamCooperBlack", 'cooper black';
	font-size: 150%;
	color: #444;
	margin: 10px 5px;	
}

.account #wrapper .my-login #content h4 {
	font-family: "BitstreamCooperBlack", 'cooper black';
	font-size: 120%;
	color: #444;
	margin: 10px 5px;	
}

.payment #wrapper .payment-wrapper h4 {
	font-family: "BitstreamCooperBlack", 'cooper black';
	font-size: 120%;
	color: #ADFFCC;
	margin: 10px 15px;	
}

Hur jag tycker det borde se ut:

h3, h4 {
	font-family: "BitstreamCooperBlack", 'cooper black';
	color: #444;
	margin:  10px 5px;
}
h3 {
	font-size: 150%;
}

h4 {
	font-size: 120%;
}

.payment-wrapper h4 {
	color: #ADFFCC;
	margin: 10px 15px;
}

Som ni ser är det mindre kod i min version, och enklare att ändra etc.

rant over!

Teknologeekerier – iPad CSS

Nu när apple har släppt sin nya iPad, kommer folk att köpa den även då den verkar vara crap.

Så då måste man nog som designer och utvecklare börja lägga till lite fler layouts och stylesheets, nog för att man inte behöver oroa sig över att göra en helt ny UI för den som har en smartphone,

Men med hjälp av CSS Media Queries har vi tidigare anpassat css för Iphones och Androids:

<link media=”only screen and (max-device-width: 480px)” href=”/iphone.css” type= ”text/css” rel=”stylesheet” />

Och igen har vi nya CSS Media Queries för iPaden:

<link rel=”stylesheet” media=”all and (orientation:portrait)” href=”portrait.css”>

<link rel=”stylesheet” media=”all and (orientation:landscape)” href=”landscape.css”>

Och om du nu utvecklat för iPhones och Androids förut så känner du säker till att safari tycker om att krympa din sida, och kringgått det med metatagen viewport

<meta name=”viewport” content=”width=device-width; initial-scale=1.0;” />

Så i grund och botten är det inte så svårt, bara en hel del css kodande efteråt.

Teknologeekerier – css3

Okey, Folk klagar på att Internet Explorer inte har CSS3 support, men mycket av vad CSS3 har gjort standard har faktiskt IE gjort sedan version 6.

Jag tycker fortfarande att Microsoft borde designa sina produkter till standard, och hatar i allmänhet deras produkter. Men instället för att klaga så kan man ju faktiskt designa sina sidor för framtiden (om Microsoft får tummen ur med IE9 eller nått).

Och nu när Google pushar Chrome så jävla hårt (fan reklam överallt i london) så har vi börjat se en ökning av Chrome läsare, några av mina sidor har mer PC Chrome användare än Mac användare.

Så nu tycker jag att det är dax att förbättra en upplevelse för användare med vettiga webbläsare som FireFox, Safari eller Chrome.

Vi kan börja med rgba(), där din fallback är filter:progid:DXImageTransform.Microsoft.gradient() för en backgrunds färg.

I webkit och Firefox kan du även göra gradients nuförtiden med
-moz-linear-gradient() och -webkit-gradient() som gör samma sak som microsofts gradient filter, än så länge vet jag inte vilken CSS3 regel som kommer att användas i framtiden.

eller om du andvänder border-radius, kan du snappa upp dessa CSS regler med curvycorners eller liknande för IE och Opera.

Runda hörn är ju en favorit design för de flesta formgivare

En annan schysst grej du kan lägga till din design för css3 webbläsare är t.ex en skugga på text med text-shadow för att ge extra läsbarhet på en knapp eller liknande.

För med saker kolla och jämför mellan IE filter och css3