2. ANCHO Y ALTURA
• La anchura y altura de un elemento no solamente se calculan
teniendo en cuenta sus propiedades width y height. El margen, el
relleno y los bordes establecidos a un elemento determinan la
anchura y altura final del elemento. En el siguiente ejemplo se
muestran los estilos CSS de un elemento:
4. MARGEN Y RELLENO
• CSS define cuatro propiedades para controlar cada uno de los
márgenes horizontales y verticales de un elemento.
• Cada una de las propiedades establece la separación entre el
borde lateral de la caja y el resto de cajas adyacentes:
5. • El ejemplo anterior de márgenes se puede reescribir utilizando la
propiedad margin:
• Código CSS original:
div img {
margin-top: .5em;
margin-bottom: .5em;
margin-left: 1em;
margin-right: .5em;
}
6. BORDES
• CSS permite modificar el aspecto de cada uno de los cuatro
bordes de la caja de un elemento. Para cada borde se puede
establecer su anchura o grosor, su color y su estilo, por lo que
en total CSS define 20 propiedades relacionadas con los
bordes.
7. • Las reglas CSS utilizadas se muestran a continuación:
div {
border-top-width: 10px;
border-right-width: 1em;
border-bottom-width: thick;
border-left-width: thin;
}
8. FONDOS
• El último elemento que forma el box model es el fondo de la caja del
elemento. El fondo puede ser un color simple o una imagen. El fondo
solamente se visualiza en el área ocupada por el contenido y su relleno,
ya que el color de los bordes se controla directamente desde los bordes y
las zonas de los márgenes siempre son transparentes.
• El siguiente ejemplo muestra una página web con un color gris claro de
fondo:
body {
background-color: #F5F5F5;
}
9. • El siguiente ejemplo muestra una imagen como fondo de toda la
página:
Imagen original
body {
background-image:url(imagenes/fondo.gif);
}
10. TIPOS DE ELEMENTOS
• Los elementos de bloque ("block elements" en inglés) siempre
empiezan en una nueva línea y ocupan todo el espacio
disponible hasta el final de la línea. Por su parte, los elementos
en línea ("inline elements" en inglés) no empiezan
necesariamente en nueva línea y sólo ocupan el espacio
necesario para mostrar sus contenidos.
11. POSICIONAMIENTO
• Los navegadores crean y posicionan de forma automática
todas las cajas que forman cada página HTML. No obstante,
CSS permite al diseñador modificar la posición en la que se
muestra cada caja.
• Posicionamiento normal o estático: se trata del
posicionamiento que utilizan los navegadores si no se indica lo
contrario.
12. • Posicionamiento flotante: se trata del modelo más especial de
posicionamiento, ya que desplaza las cajas todo lo posible
hacia la izquierda o hacia la derecha de la línea en la que se
encuentran.
13. VISUALIZACIÓN
• Además de las propiedades que controlan el posicionamiento
de los elementos, CSS define otras cuatro propiedades para
controlar su visualización: display, visibility, overflow y z-index.
• Utilizando algunas de estas propiedades es posible ocultar y/o
hacer invisibles las cajas de los elementos, por lo que son
imprescindibles para realizar efectos avanzados y
animaciones.
14. • Posicionamiento absoluto: la posición de una caja se establece
de forma absoluta respecto de su elemento contenedor y el
resto de elementos de la página ignoran la nueva posición del
elemento.
15. TEXTO
• CSS define numerosas propiedades para modificar la apariencia
del texto. A pesar de que no dispone de tantas posibilidades
como los lenguajes y programas específicos para crear
documentos impresos, CSS permite aplicar estilos complejos y
muy variados al texto de las páginas web.
h1 { color: #369; }
p { color: black; }
a, span { color: #B1251E; }
div { color: rgb(71, 98, 176); }
17. ENLACES
• Los estilos más sencillos que se pueden aplicar a los enlaces
son los que modifican su tamaño de letra, su color y la
decoración del texto del enlace. Utilizando las
propiedades text-decoration yfont-weight se pueden
conseguir estilos como los que se muestran en la siguiente
imagen:
18. a { margin: 1em 0; display: block;}.alternativo {color: #CC0000;}
.simple {text-decoration: none;}
.importante {font-weight: bold; font-size: 1.3em;}
.raro {text-decoration:overline;}
<a href="#">Enlace con el estilo por defecto</a>
<a class="alternativo" href="#">Enlace de color rojo</a>
<a class="simple" href="#">Enlace sin subrayado</a>
<a class="importante" href="#">Enlace muy importante</a>
<a class="raro" href="#">Enlace con un estilo raro</a>
19.
20. IMÁGENES
• Utilizando las propiedades width y height, es posible mostrar las
imágenes con cualquier altura/anchura, independientemente de su
altura/anchura real:
#destacada {
width: 120px;
height: 250px;
}
<img id="destacada" src="imagen.png" />
21. LISTAS
• Por defecto, los navegadores muestran los elementos de las
listas no ordenadas con una viñeta formada por un pequeño
círculo de color negro. Los elementos de las listas ordenadas
se muestran por defecto con la numeración decimal utilizada
en la mayoría de países.
23. TABLAS
• Cuando se aplican bordes a las celdas de una tabla, el aspecto
por defecto con el que se muestra en un navegador es el
siguiente:
24. • El código CSS completo del ejemplo
anterior se muestra a continuación:
normal {
width: 250px;
border: 1px solid #000;
border-collapse:collapse;
}
normal th, .normal td {
border: 1px solid #000;
}
<table class="normal" summary="Tabla
genérica">
<tr>
<th scope="col">A</th>
<th scope="col">B</th>
<th scope="col">C</th>
<th scope="col">D</th>
<th scope="col">E</th>
</tr>
</table>
25. FORMULARIOS
• Como ya se vio anteriormente, el estilo por defecto de los
enlaces se puede modificar para que se muestren como
botones de formulario. Ahora, los botones de formulario
también se pueden modificar para que parezcan enlaces.
26. Las reglas CSS del ejemplo anterior son las siguientes:
enlace {
border: 0;
padding: 0;
background-color: transparent;
color: blue;
border-bottom: 1px solid blue;
}
<input type="button" value="Botón normal" />
<input class="enlace" type="button" value="Botón como enlace" />