sábado, 28 de abril de 2012

MARCOS


16.Introducción a los marcos

Los marcos HTML permiten a los autores presentar documentos con vistas múltiples, que pueden ser ventanas o subventanas independientes. Las vistas múltiples ofrecen a los autores una manera de mantener cierta información visible mientras otras vistas se desplazan o se sustituyen. Por ejemplo, dentro de una misma ventana, un marco podría mostrar un gráfico estático, un segundo marco un menú de navegación, y un tercero el documento principal que puede ser desplazado, o reemplazado al navegar por el segundo marco.
Aquí tenemos un documento simple con marcos:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Frameset//EN"
"http://www.w3.org/TR/html4/frameset.dtd"> <HTML>
</HEAD
<HEAD> <TITLE>Un documento simple con marcos</TITLE> >
<FRAME src="conteni
<FRAMESET cols="20%, 80%"> <FRAMESET rows="100, 200" >dos_del_marco1.html"> <FRAME src="contenidos_del_marco2.gif">
<P>Est
</FRAMESET> <FRAME src="contenidos_del_marco3.html"> <NOFRAMES >e conjunto de marcos contiene: <UL>
.html">Contenidos chéveres</A> <LI><IMG src="contenidos_del_marc
<LI><A href="contenidos_del_marco 1o2.gif" alt="Una imagen chévere"> <LI><A href="contenidos_del_marco3.html">Más contenidos chéveres
</A>
</UL> </NOFRAMES> </FRAMESET>
</HTML>
Esto podría crear una disposición de marcos como la siguiente:
---------------------------------------
| | |
| | |
| | |
| Marco 1 | | | | |
| | |
|---------| | | | Marco 3 | | | |
| | |
| | | | Marco 2 | | | | | | | |
| | |
---------------------------------------
Si el agente de usuario no puede mostrar marcos o está configurado para no mostrarlos, representará los contenidos del elemento NOFRAMES.

16.2 Disposición de los marcos

Los documentos HTML que describen una disposición de marcos (llamados documentos con marcos) tienen una estructura diferente a la de los documentos HTML sin marcos. Un documento normal tiene una sección HEAD y una sección BODY. Un documento con marcos tiene una sección HEAD, y un FRAMESET en lugar del BODY.
La sección FRAMESET de un documento especifica la disposición de las vistas en la ventana principal del agente de usuario. Además, la sección FRAMESET puede contener un elemento NOFRAMES que proporcione contenido alternativo para los agentes de usuario que no soporten marcos o que estén configurados para no mostrar marcos.
Los elementos que normalmente podrían colocarse en el elemento BODY no deben aparecer antes del primer elemento FRAMESET o el FRAMESET no será tenido en cuenta.


rows = lista de multilongitudes [CN]
Este atributo especifica la disposición de los marcos horizontales. Es una lista de longitudes en píxeles, porcentajes o longitudes relativas, separadas por comas. El valor por defecto es 100%, que significa una fila.
cols = lista de multilongitudes [CN]
Este atributo especifica la disposición de los marcos verticales. Es una lista de longitudes en píxeles, porcentajes o longitudes relativas, separadas por comas. El valor por defecto es 100%, que significa una columna.
El elemento FRAMESET especifica la organización de la ventana principal del usuario en términos de subespacios rectangulares.

Filas y columnas 

Cuando se establece el atributo rows (filas) se define el número de subespacios horizontales. Cuando se establece el atributo cols (columnas) se define el número de subespacios verticales. Ambos atributos se pueden especificar simultáneamente para crear una cuadrícula.
Si no se establece el atributo rows, cada columna se extiende a lo largo de toda la longitud de la página. Si no se establece el atributo cols, cada fila se extiende a lo largo de toda la anchura de la página. Si no se establece ninguno de los dos atributos, el marco tiene exactamente el mismo tamaño que la página.
Los marcos se crean de izquierda a derecha para las columnas y de arriba a abajo
 para las filas. Cuando se especifican ambos atributos, las vistas se crean de 
izquierda a derecha en la fila superior, de izquierda a derecha en la segunda fila, etc.
En este primer ejemplo dividimos la pantalla verticalmente en dos (es decir, creamos 
una mitad superior y una mitad inferior).
<FRAMESET rows="50%, 50%">
...el resto de la definición...</FRAMESET>
El siguiente ejemplo crea tres columnas: la segunda tiene una anchura fija de 
250 píxeles (lo cual es útil, por ejemplo, para incluir una imagen de tamaño conocido).
 La primera recibe el 25% del espacio restante, y la tercera el 75% del espacio restante.
<FRAMESET cols="1*,250,3*">
...el resto de la definición...</FRAMESET>
El siguiente ejemplo crea una cuadrícula de 2x3 subespacios.
<FRAMESET rows="30%,70%" cols="33%,34%,33%">
...el resto de la definición...</FRAMESET>
Para el siguiente ejemplo, supongamos que la ventana del navegador tiene
 actualmente una altura de 1000 píxeles. Para la primera vista se asigna el 30%
 de la altura total (300 píxeles). Para la segunda vista se especifica que tenga una 
altura de exactamente 400 píxeles. Esto deja 300 píxeles para repartir entre los otros
 dos marcos. La altura del cuarto marco se ha especificado como "2*", 
de modo que es el doble de alto que el tercer marco, cuya altura es sólo "*" 
(equivalente a 1*). Por tanto el tercer marco será de 100 píxeles de alto y el 
cuarto tendrá una altura de 200 píxeles..
<FRAMESET rows="30%,400,*,2*">
...el resto de la definición...</FRAMESET>
Las longitudes absolutas que no sumen el 100% del espacio real disponible 
deberían ser ajustadas por los agentes de usuario. Cuando sobre espacio, 
el espacio sobrante debería repartirse proporcionalmente entre cada vista. 
Cuando falte espacio, debería reducirse cada vista en función de la relación 
entre el espacio especificado y el espacio total.

Anidamiento de grupos de marcos 

Los grupos de marcos pueden anidarse hasta cualquier nivel.
En el siguiente ejemplo, el FRAMESET exterior divide el espacio disponible en tres
 columnas iguales. 
A continuación el FRAMESET interior divide la segunda área en dos filas de alturas diferentes.
<FRAMESET cols="33%, 33%, 34%">
...contenidos del primer marco...
<FRAMESET rows="40%, 50%">
...contenidos del segundo marco, primera fila...
...contenidos del segundo marco, segunda fila...
</FRAMESET>
...contenidos del tercer marco...
</FRAMESET>

Compartir datos entre marcos 

Los autores pueden compartir datos entre varios marcos incluyendo estos datos a través de un elemento OBJECT. Los autores deberían incluir el elemento OBJECT en el elemento HEADdel documento con marcos y darle un nombre con el atributo id. Cualquier documento que sea el contenido de un marco del documento con marcos puede hacer referencia a este identificador.
El siguiente ejemplo ilustra cómo podría hacer referencia un script a un elemento OBJECT 
definido para todo un grupo de marcos:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Frameset//EN"
"http://www.w3.org/TR/html4/frameset.dtd"> <HTML>
OBJECT
<HEAD> <TITLE>Esto es un documento con marcos con un en el HEAD</TITLE>
se representa! --> <OBJECT id="miobjeto
<!-- ¡Este OBJECT no " data="datos.dat"></OBJECT> </HEAD> <FRAMESET>
MESET> </HTML> <!-- En blanca.html --> <HT
<FRAME src="blanca.html" name="blanca"> </FR AML> <HEAD> <TITLE>Página de Blanca</TITLE> </HEAD> <BODY>
...comienzo del documento...
<P>
<SCRIPT type="text/javascript">
parent.miobjeto.mipropiedad
</SCRIPT>
...el resto del documento...
</BODY>
</HTML>

name = cdata [CI]
Este atributo asigna un nombre al marco actual. Este nombre puede utilizarse como el destino de vínculos subsiguientes.
longdesc = uri [CT]
Este atributo especifica un vínculo a una descripción larga del marco. Esta descripción debería complementar la descripción corta proporcionada por el atributo title, y puede ser particularmente útil para agentes de usuario no visuales.
src = uri [CT]
Este atributo especifica la localización de los contenidos iniciales que contendrá el marco.
noresize [CI]
Si está presente, este atributo booleano le dice al agente de usuario que la ventana del marco no debe ser redimensionable.
scrolling = auto|yes|no [CI]
Este atributo especifica información sobre el desplazamiento de la ventana del marco. Valores posibles:
  • auto: Este valor le dice al agente de usuario que proporcione mecanismos de desplazamiento en la ventana del marco cuando sea necesario. Este es el valor por defecto.
  • yes: Este valor le dice al agente de usuario que siempre proporcione mecanismos de desplazamiento en la ventana del marco.
  • no: Este valor le dice al agente de usuario que nunca proporcione mecanismos de desplazamiento en la ventana del marco.
frameborder = 1|0 [CN]
Este atributo proporciona información al agente de usuario sobre el borde del marco. Valores posibles:
  • 1: Este valor le dice al agente de usuario que dibuje un separador entre este marco y todos los marcos adyacentes. Este es el valor por defecto.
  • 0: Este valor le dice al agente de usuario que no dibuje un separador entre este marco y todos los marcos adyacentes. Obsérvese que aún se puede dibujar un separador junto a este marco si así se especifica para otros marcos.
marginwidth = píxeles [CN]
Este atributo especifica la cantidad de espacio que debe dejarse entre los contenidos del marco en sus márgenes izquierdo y derecho. El valor debe ser mayor o igual que cero (píxeles). El valor por defecto depende del agente de usuario.
marginheight = píxeles [CN]
Este atributo especifica la cantidad de espacio que debe dejarse entre los contenidos del marco en sus márgenes superior e inferior. El valor debe ser mayor o igual que cero (píxeles). El valor por defecto depende al agente de usuario.
El elemento FRAME define los contenidos y la apariencia de un marco dado.

Especificación de los contenidos iniciales de un marco 

El atributo src especifica el documento inicial que contendrá el marco.
El siguiente ejemplo de documento HTML:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Frameset//EN"
"http://www.w3.org/TR/html4/frameset.dtd"> <HTML>
<FRAM
<HEAD> <TITLE>Un documento con marcos</TITLE> </HEAD >ESET cols="33%,33%,33%"> <FRAMESET rows="*,200">
<FRAME src="contenidos_del_marco2.gif"> </F
<FRAME src="contenidos_del_marco1.html"> RAMESET> <FRAME src="contenidos_del_marco3.html"> <FRAME src="contenidos_del_marco4.html">
</FRAMESET>
</HTML>
debería crear una distribución de marcos parecida a ésta:
------------------------------------------
|Marco 1 |Marco 3 |Marco 4 |
| | | |
| | | |
| | | | | | | |
| | | |
| | | | | | | | -------------| | |
------------------------------------------
|Marco 2 | | | | | | |
| | | |


y hacer que el agente de usuario cargara cada fichero en una vista separada.
Los contenidos de un marco no deben estar en el mismo documento que la definición del marco.


EJEMPLO ILEGAL: 
La siguiente definición de un grupo de marcos no es legal según HTML, ya que los contenidos del segundo marco están en el mismo documento que la definición del grupo de marcos.


El siguiente ejemplo ilustra el uso de los atributos decorativos de FRAME. Especificamos que el
 marco 1 no permitirá barras de desplazamiento. El marco 2 dejará espacio en blanco
 alrededor de sus contenidos (inicialmente, un fichero de imagen) y el marco 
no será redimensionable. No se dibujará ningún borde entre los marcos 3 y 4.
 Se dibujarán los bordes (por defecto) entre los marcos 1, 2 y 3.
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Frameset//EN"
"http://www.w3.org/TR/html4/frameset.dtd"> <HTML>
<FRAM
<HEAD> <TITLE>Un documento con marcos</TITLE> </HEAD >ESET cols="33%,33%,33%"> <FRAMESET rows="*,200">
ing="no"> <FRAME src="contenidos_del_marco2.gif"
<FRAME src="contenidos_del_marco1.html" scrol marginwidth="10" marginheight="15" noresize> </FRAMESET>
os_del_marco4.html" frameborder="0"> </FRAMESET> </HTML>
<FRAME src="contenidos_del_marco3.html" frameborder="0"> <FRAME src="contenido>
d

3 Especificación de información sobre el marco destino

Nota. Para información sobre las prácticas actuales referentes a la determinación del marco destino, consulte las notas sobre marcos del apéndice.
Definiciones de atributos
target = marco-destino [CI]
Este atributo especifica el nombre de un marco en el que debe abrirse un documento.
Al asignar un nombre a un marco por medio del atributo name, los autores pueden referirse a él como el "destino" de los vínculos definidos por otros elementos. Se pueden establecer el atributo target para los elementos que creen vínculos (A, LINK), para los mapas de imágenes (AREA), y para los formularios (FORM).
Consulte la sección sobre nombres de marcos destino para información sobre nombres de marcos reconocidos.
Este ejemplo ilustra cómo es posible mediante la especificación de un destino la 
modificación dinámica de los contenidos de un marco. Primero definimos un grupo de 
marcos en el documento frameset.html, mostrado a continuación:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Frameset//EN"
"http://www.w3.org/TR/html4/frameset.dtd"> <HTML>
<FRAM
<HEAD> <TITLE>Un documento con marcos</TITLE> </HEAD >ESET rows="50%,50%">
src="inicial_fijo.html"> <FRAME name="dinam
<FRAME name="fijo" ico" src="inicial_dinamico.html"> </FRAMESET>
</HTML>
Después, en inicial_dinamico.html, hacemos un vínculo al marco llamado "dinamico".
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd"> <HTML> <HEAD>
</TITLE> </HEAD> <BODY>
<TITLE>Un documento con vínculos con destinos específico
s...comienzo del documento...
<P>Puede avanzar ahora a la
<A href="diapo2.html" target="dinamico">diapositiva 2.</A>
...más documento...<P>Lo está haciendo muy bien. Vaya ahora a la  
  <A href="diapo3.html" target="dinamico">diapositiva 3.</A></BODY>
</HTML>
Si se activa cualquiera de los vínculos se abre un nuevo documento en 
el marco llamado "dinamico", mientras que el otro marco, "fijo", 
mantiene sus contenidos iniciales.

16.3.1 Especificación del destino de los vínculos por defecto

Cuando muchos vínculos del mismo documento designan al mismo destino, es posible especificar el destino una sola vez para que no sea necesario incluir el atributo target en todos los elementos. Esto se hace estableciendo el atributo target del elemento BASE.
Volvemos al ejemplo anterior, esta vez definiendo la información sobre el destino en el
 elemento BASE para quitarla de los elementos A.
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"
"http://www.w3.org/TR/html4/loose.dtd"> <HTML> <HEAD>
TLE> <BASE href="http://www.micom.com/Diapos" target="dinamic
<TITLE>Un documento con un destino específico en BASE</T Io"> </HEAD> <BODY>
...comienzo del documento...
<P>Puede avanzar ahora a la <A href="diapo2.html">diapositiva 2.</A>
...más documento...<P>Lo está haciendo muy bien. Vaya ahora a la  
<A href="diapo3.html">diapositiva 3.</A></BODY>
</HTML>

16.3.2 Semántica de marcos destino

Los agentes de usuario deberían determinar el marco destino en el que cargar un recurso vinculado de acuerdo con las siguientes reglas de precedencia (ordenadas de mayor a menor prioridad):
  1. Si un elemento especifica en su atributo target un marco conocido, cuando se activa el vínculo (p.ej., se sigue el vínculo o se procesa un formulario), el recurso designado por el elemento debería cargarse en el marco destino.
  2. Si un elemento no tiene el atributo target establecido pero el elemento BASE sí lo tiene, el atributo target del elemento BASE determina el marco.
  3. Si ni el elemento que vincula el recurso ni el elemento BASE hacen referencia a un destino, el recurso designado por el elemento debería cargarse en el marco que contiene al elemento.
  4. Si alguno de los atributos target se refiere a un marco desconocido F, el agente de usuario debería crear una ventana y marco nuevos, asignar el nombre F al marco, y cargar el recurso designado por el elemento en el nuevo marco.
Los agentes de usuario pueden proporcionar a los usuarios un mecanismo para deshabilitar el atributo target.

16.4 Contenido alternativo

Los autores deberían proporcionar contenido alternativo para aquellos agentes de usuario que no soporten marcos o que estén configurados para no mostrar marcos.
El elemento NOFRAMES especifica un contenido que sólo deberían mostrar los agentes de usuario que no soporten marcos o que estén configurados para no mostrar marcos. Los agentes de usuario que soporten marcos sólo deben mostrar los contenidos de una declaración NOFRAMES cuando se configuren para no mostrar marcos. Los agentes de usuario que no soporten marcos deben mostrar los contenidos de NOFRAMES en cualquier caso.
El elemento NOFRAMES es parte tanto del DTD transicional como del de documentos con marcos. En un documento que use el DTD de documentos con marcos, NOFRAMES se puede usar al final de la sección FRAMESET del documento.
Por ejemplo:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Frameset//EN"
"http://www.w3.org/TR/html4/frameset.dtd"> <HTML>
</TITLE>
<HEAD> <TITLE>Un documento con marcos con NOFRAME S </HEAD> <FRAMESET cols="50%, 50%">
RAME src="tabla_de_contenidos.htm
<FRAME src="principal.html"> < Fl"> <NOFRAMES>
contrar la <A href="principal-sinmarcos.html"> versio
<P>Aquí puede e nn sin marcos del documento.</A> </NOFRAMES> </FRAMESET>
</HTML>
NOFRAMES se puede usar, por ejemplo, en un documento que sea el origen de un marco y que use el DTD transicional. Esto permite a los autores explicar el propósito del documento en los casos en que éste se vea fuera del grupo de marcos o con un agente de usuario que no soporte marcos.

16.4.2 Descripciones largas de marcos

El atributo longdesc permite a los autores hacer los documentos con marcos más accesibles a las personas que utilizan agentes de usuario no visuales. Este atributo designa un recurso que proporciona una descripción larga del marco. Los autores deberían recordar que las descripciones largas asociadas con los marcos se refieren al marco, y no a los contenidos del marco. Como los contenidos pueden variar con el tiempo, la descripición larga inicial podría ser inapropiada para los contenidos posteriores del marco. En particular, los autores no deberían incluir una imagen como único contenido de un marco.
El siguiente documento con marcos describe dos marcos. El marco izquierdo contiene 
una tabla de contenidos y el marco derecho contiene inicialmente la imagen de un avestruz:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Frameset//EN"
   "http://www.w3.org/TR/html4/frameset.dtd">
<HTML>
<HEAD>
<TITLE>Un documento con marcos mal diseñado</TITLE>
</HEAD>
<FRAMESET cols="20%, 80%">
   <FRAME src="tabla_de_contenidos.html">
   <FRAME src="avestruz.gif" longdesc="desc-avestruz.html">
</FRAMESET>
</HTML>
Obsérvese que la imagen ha sido incluida en el marco independientemente de 
cualquier elemento HTML, de modo que el autor no tiene ninguna manera de 
especificar un texto alternativo aparte de usar el atributo longdesc
Si los contenidos del marco derecho cambian (p.ej., el usuario 
selecciona una serpiente de cascabel en la tabla de contenidos), 
los usuarios no tendrán acceso textual a los nuevos contenidos del marco.
Por tanto, los autores no deberían poner una imagen en un marco directamente. 
En su lugar, la imagen debería especificarse en un documento HTML independiente,
 en el cual se podría adjuntar el texto alternativo apropiado:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Frameset//EN"
   "http://www.w3.org/TR/html4/frameset.dtd">
<HTML>
<HEAD>
<TITLE>Una documento con marcos bien diseñado</TITLE>
</HEAD>
<FRAMESET cols="20%, 80%">
   <FRAME src="tabla_de_contenidos.html">
   <FRAME src="contenedor_avestruz.html">
</FRAMESET>
</HTML>
<!-- En contenedor_avestruz.html: -->
<HTML>
<HEAD>
<TITLE>El avestruz, robusto y veloz</TITLE>
</HEAD>
<P>
<OBJECT data="avestruz.gif" type="image/gif">
¡Estos avestruces seguro que están ricos!
</OBJECT>
</HTML>

16.5 Marcos en línea: el elemento IFRAME


longdesc = uri [CT]
Este atributo especifica un vínculo a una descripción larga del marco. Esta descripción debería servir como complemento de la descripción corta que proporciona el atributotitle, y es particularmente útil para los agentes de usuario no visuales.
name = cdata [CI]
Este atributo asigna un nombre al marco actual. Este nombre puede utilizarse como el destino de vínculos subsiguientes.
width = longitud [CN]
La anchura del marco en línea.
height = longitud [CN]
La altura del marco en línea.
El elemento IFRAME permite a los autores insertar un marco dentro de un bloque de texto. Insertar un marco en línea dentro de una sección de texto es muy similar a insertar un objeto mediante un elemento OBJECT: ambos permiten insertar un documento HTML en medio de otro, ambos pueden alinearse con el texto circundante, etc.
La información a insertar en línea se designa mediante el atributo src de este elemento. Los contenidos del elemento IFRAME, por su parte, sólo deberían ser mostrados por los agentes de usuario que no soporten marcos o que estén configurados para no mostrar marcos.
Para aquellos agentes de usuario que soporten marcos, el siguiente ejemplo colocará un 
marco en línea rodeado por un borde en medio del texto.
  <IFRAME src="blabla.html" width="400" height="500"
          scrolling="auto" frameborder="1">
  [Su agente de usuario no soporta marcos o está actualmente configurado
  para no mostrar marcos. Sin embargo, puede visitar
  <A href="blabla.html">el documento relacionado.</A>]
  </IFRAME>
Los marcos en línea no pueden ser redimensionados (y por lo tanto no tienen un atributo noresize).

No hay comentarios:

Publicar un comentario