Vou começar uma série de artigos para otimização de códigos CSS.
Há um tempinho atrás, na empresa que eu trabalho, me pediram para reduzir o tamanho dos arquivos CSS de um sistema web. Estavam muito bagunçados, sem falar que tinha um arquivo para praticamente cada página. Cuidado com o uso excessivo de arquivos separados, é certo usá-los, mas moderadamente para que não ocupem espaço na publicação/hospedagem.
Bom, a primeira dica que eu vou dar é a de "aninhar" algumas propriedades do CSS, chama-se Declaração Única.
Abaixo tem as principais propriedades que podem ser declaradas dessa forma:
Margin e Padding
.exemplo1 { /*completo*/
margin-top:0;
margin-right:5px;
margin-bottom:10px;
margin-left:15px;
/*auto, 0, px, pt, em ou %*/
}
.exemplo1 { /*aninhado*/
margin:0 5px 10px 15px;
/*top right bottom left*/
}
.exemplo2 {
margin-top:10px;
margin-right:20px;
margin-bottom:0;
margin-left:20px;
}
.exemplo2 {
margin:10px 20px 0;
/*top right/left bottom*/
}
.exemplo3 {
margin-top:0;
margin-right:auto;
margin-bottom:0;
margin-left:auto;
}
.exemplo3 {
margin:0 auto;
/*top/bottom left/right*/
}
.exemplo4 {
margin-top:50px;
margin-right:50px;
margin-bottom:50px;
margin-left:50px;
}
.exemplo4 {
margin:50px;
/*top/right/bottom/left*/
}
Border
.exemplo1 { /*completo*/
border-width:5px;
/*thin, thick, medium ou value
*default = medium*/
border-style:dotted;
/*solid, dashed, dotted, double etc
*default = none*/
border-color:blue;
/*nome em inglês, hex, rgb ou 0-255
*default = valor dos elementos de propriedades superiores*/
}
.exemplo1 { /*aninhado*/
border:5px dotted blue;
}
.exemplo2 {
border-right-width:2px;
border-right-style:solid;
border-right-color:#666666;
}
.exemplo2 {
border-right:2px solid #666
}
.exemplo3 {
border-top-width:3px;
border-right-width:2px;
border-bottom-width:3px;
border-left-width:2px;
}
.exemplo3 {
border-width:3px 2px;
}
Background
.exemplo1 { /*completo*/
background-color:#CCCCCC;
/*nome da cor em inglês, hex, rgb ou 0-255
*default = transparent*/
background-image:url(images/bg.gif);
/*url ou none
*default = none*/
background-repeat:no-repeat;
/*repeat, repeat-x, repeat-y ou no-repeat
*default = repeat*/
background-attachment:scroll;
/*fixed ou scroll
*default = scroll*/
background-position:top left;
/*top, right, left, bottom ou center
*default = 0% 0%*/
}
.exemplo1 { /*aninhado*/
background:#CCC url(images/bg.gif) no-repeat 0 0;
}
Font
.exemplo1 { /*completo*/
font-family:Verdana, Arial, Helvetica;
/*Verdana, Arial, "Times New Roman" etc
*default = fonte do navegador*/
font-size:12px;
/*xx-small, medium, x-large, value etc
*default = medium*/
font-weight:bold;
/*normal, bold, bolder, lighter, 100-900 ou inherit
*default = normal*/
font-style:italic;
/*normal, italic ou oblique
*default = normal*/
font-variant:normal;
/*normal ou small-caps
*default = normal*/
line-height:1.5;
/*normal, px, pt, em, num ou %
*default = normal*/
}
.exemplo1 { /*aninhado*/
font:italic bold 12px/1.5 Verdana, Arial, Helvetica;
}
List
.exemplo1 { /*completo*/
list-style-image:url(images/bullet.gif);
/*url ou none
*default = none*/
list-style-position:inside;
/*inside ou outside
*default = outside*/
list-style-type:square;
/*circle, disc, square etc
*default = disc*/
}
.exemplo1 { /*aninhado*/
list-style:square inside url(images/bullet.gif);
}
Tente usar essa dica nos seus códigos e com o tempo você acaba se acostumando a fazê-los sempre assim.
Abaixo listo alguns sites de otimização de CSS, e com o tempo, tentarei passar outros truques:
Até mais.
É realmente importante se preocupar com a otimização e em ocupar menor espaço, principalmente quando existe concorrência. Não conhecia este aninhamento, parabéns!
ResponderExcluir