Código ejemplo: manejadores de eventos.
<!DOCTYPE html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Test</title>
<!-- Estilo Css -->
<style type="text/css">
#menu ul,#menu li,#menu span,#menu a {
position: relative;
margin: 0;
padding: 0;
}
#menu {
height: 49px;
width: auto;
border-radius: 10px;
background: #800000; /*Color igual al triángulo apuntador de selección */
border-bottom: 2px solid #C44000;
}
#menu a {
background: #C44000;
color: #fff;
display: inline-block;
font-family: Helvetica, Arial, Verdana, sans-serif;
font-size: 12px;
line-height: 49px;
padding: 0 20px;
text-decoration: none;
}
#menu ul {
list-style: none;
}
#menu > ul, #menu > ul > li {
float: left;
}
#menu > ul > li > a {
color: #FC0; /* Maíz */
font-size: 12px;
}
#menu > ul > li:first-child > a {
border-radius: 5px 0 0 5px; /* Superior derecho, sigue el sentido de las agujas de un reloj */
}
#menu > ul > li:last-child > a {
border-radius: 0 5px 5px 0; /* Superior izquierdo, sigue el sentido de las agujas de un reloj */
}
#menu > ul > li.elementomenu > a {
-webkit-box-shadow: inset 0 0 3px #000;
background: url(file:///C|/Escuela2013/Imagenes/FondoBotonesMenu.jpg); /* Color de fondo bordó en imagen */
}
/* Código para simular el apuntador */
#menu > ul > li:hover:after {
content: ''; /*Pseudo clase :after --> Inserta contenido después de ... En este caso el contenido es nulo, sólo con formato */
/* Ubicar el contenido insertado */
width: 0px;
height: 0px;
position: absolute;
left: 50%;
top: 40px;
/* Dar formato al contenido insertado */
border-left: 10px solid transparent; /* Formato del triángulo apuntador */
border-right: 10px solid transparent; /* Formato del triángulo apuntador */
border-bottom: 10px solid #800000; /* Triángulo apuntador de selección color igual al color del fondo del menú */
margin-left: -10px; /* Posición del triángulo apuntador */
}
#menu > ul > li:hover > a {
background: #FC0; /* Maíz */
box-shadow: inset 0 0 5px #FFCC00; /* Amarillo claro */
color: #000;
}
#menu .subelemento {
z-index: 1;
}
#menu .subelemento ul {
display: none;
position: absolute;
width: 200px;
top: 100%;
left: 0;
}
#menu .subelemento ul li {
margin-bottom: 0px; /* Separación entre los subelementos */
}
#menu .subelemento ul li a {
background: #800000; /* Bordó */
border-bottom: 1px dotted #FC0; /* Maíz */
filter: none;
font-size: 11px;
display: block;
line-height: 120%;
padding: 10px;
color: #fff;
}
#menu .subelemento:hover ul{
display: block;
}
#menu .subelemento ul li:hover a {
background: #000;
}
#menu .subelemento .subelemento:hover > ul {
display: block;
}
#menu .subelemento .subelemento ul {
display: none;
position: absolute;
left: 100%;
top: 0;
}
#menu .subelemento .subelemento ul li a {
background: #000; /* Color de fondo del elemento cuando está seleccionado */
border-bottom: 1px dotted #FC0; /* Maíz */
}
#menu .subelemento .subelemento ul li a:hover {
background:#FC0; /* Maíz */
color: #000; /* Negro */
}
</style>
<!-- Código JavaScript -->
<script type="text/javascript">
window.onload = function(){
window.document.getElementById('msId').onclick = mensaje;
window.document.getElementById('ImgMsId').onmouseover = cambioColor;
window.document.getElementById('ImgMsId').onmouseout = colorOriginal;
window.document.getElementById('costosemanal').onclick = function(){
calculareserva(7, 155);
}
}
function mensaje(){
alert('Manejador semántico con ID');
}
function cambioColor(){
window.document.body.bgColor = '#000';
}
function colorOriginal(){
window.document.body.bgColor = '#fff';
}
/* Función nombrada sin argumentos */
function valorareserva(){
var costosemana;
costosemana= parseInt(7 * 155);
alert('Función nombrada sin parámetros: valorareserva. El costo de la estadía es de $' + costosemana);
}
/* Función nombrada con argumentos */
function calculareserva(dias, costoxdia){
var costosemana;
costosemana= parseInt(dias * costoxdia);
alert('Función nombrada con argumentos: calculareserva. El costo de la estadía es de $' + costosemana);
}
</script>
</head>
<body>
<div id="menu">
<ul>
<li class="elementomenu"><a href="#" id="msId"><span>Inicio</span></a></li>
<li class="subelemento"><a href="#"><span>Complejo</span></a>
<ul>
<li class="subelemento"><a href="#"><span>Presupuestos</span></a>
<ul>
<!-- Ejemplo: código javascript asociado a una etiqueta.-->
<li><a href="javascript: alert('Sin función, código directo. El costo de la estadía es de $' + (7 * 155));"><span>Calcular costo reserva por 7 días</span></a></li>
<!-- Ejemplo: función nombrada sin parámetros asociada a un manejador de eventos de etiqueta.
<li><a href="javascript: valorareserva();"><span>Calcular costo reserva por 7 días</span></a></li>-->
<!-- Ejemplo: función nombrada con parámetros asociada a un manejador de eventos de etiqueta.
<li><a href="javascript: calculareserva(7, 155);"><span>Calcular costo reserva por 7 días</span></a></li>-->
<!-- Ejemplo: función anónima con parámetros asociada a un manejador de eventos semántico.
<li><a href="#" id="costosemanal"><span>Calcular costo estadía por 7 días</span></a></li>-->
<li><a href="#"><span>Calcular días de descuento</span></a></li>
</ul>
</li>
<li class="subelemento"><a href="#"><span>Servicios</span></a>
<ul>
<li><a href="#"><span>Desayuno Americano</span></a></li>
<li><a href="#"><span>Spa</span></a></li>
</ul>
</li>
</ul>
</li>
<li><a href="#"><span>Reservas</span></a></li>
<li><a href="#" id="ImgMsId"><span>Contacto</span></a></li>
</ul>
</div>
</body>
</html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Test</title>
<!-- Estilo Css -->
<style type="text/css">
#menu ul,#menu li,#menu span,#menu a {
position: relative;
margin: 0;
padding: 0;
}
#menu {
height: 49px;
width: auto;
border-radius: 10px;
background: #800000; /*Color igual al triángulo apuntador de selección */
border-bottom: 2px solid #C44000;
}
#menu a {
background: #C44000;
color: #fff;
display: inline-block;
font-family: Helvetica, Arial, Verdana, sans-serif;
font-size: 12px;
line-height: 49px;
padding: 0 20px;
text-decoration: none;
}
#menu ul {
list-style: none;
}
#menu > ul, #menu > ul > li {
float: left;
}
#menu > ul > li > a {
color: #FC0; /* Maíz */
font-size: 12px;
}
#menu > ul > li:first-child > a {
border-radius: 5px 0 0 5px; /* Superior derecho, sigue el sentido de las agujas de un reloj */
}
#menu > ul > li:last-child > a {
border-radius: 0 5px 5px 0; /* Superior izquierdo, sigue el sentido de las agujas de un reloj */
}
#menu > ul > li.elementomenu > a {
-webkit-box-shadow: inset 0 0 3px #000;
background: url(file:///C|/Escuela2013/Imagenes/FondoBotonesMenu.jpg); /* Color de fondo bordó en imagen */
}
/* Código para simular el apuntador */
#menu > ul > li:hover:after {
content: ''; /*Pseudo clase :after --> Inserta contenido después de ... En este caso el contenido es nulo, sólo con formato */
/* Ubicar el contenido insertado */
width: 0px;
height: 0px;
position: absolute;
left: 50%;
top: 40px;
/* Dar formato al contenido insertado */
border-left: 10px solid transparent; /* Formato del triángulo apuntador */
border-right: 10px solid transparent; /* Formato del triángulo apuntador */
border-bottom: 10px solid #800000; /* Triángulo apuntador de selección color igual al color del fondo del menú */
margin-left: -10px; /* Posición del triángulo apuntador */
}
#menu > ul > li:hover > a {
background: #FC0; /* Maíz */
box-shadow: inset 0 0 5px #FFCC00; /* Amarillo claro */
color: #000;
}
#menu .subelemento {
z-index: 1;
}
#menu .subelemento ul {
display: none;
position: absolute;
width: 200px;
top: 100%;
left: 0;
}
#menu .subelemento ul li {
margin-bottom: 0px; /* Separación entre los subelementos */
}
#menu .subelemento ul li a {
background: #800000; /* Bordó */
border-bottom: 1px dotted #FC0; /* Maíz */
filter: none;
font-size: 11px;
display: block;
line-height: 120%;
padding: 10px;
color: #fff;
}
#menu .subelemento:hover ul{
display: block;
}
#menu .subelemento ul li:hover a {
background: #000;
}
#menu .subelemento .subelemento:hover > ul {
display: block;
}
#menu .subelemento .subelemento ul {
display: none;
position: absolute;
left: 100%;
top: 0;
}
#menu .subelemento .subelemento ul li a {
background: #000; /* Color de fondo del elemento cuando está seleccionado */
border-bottom: 1px dotted #FC0; /* Maíz */
}
#menu .subelemento .subelemento ul li a:hover {
background:#FC0; /* Maíz */
color: #000; /* Negro */
}
</style>
<!-- Código JavaScript -->
<script type="text/javascript">
window.onload = function(){
window.document.getElementById('msId').onclick = mensaje;
window.document.getElementById('ImgMsId').onmouseover = cambioColor;
window.document.getElementById('ImgMsId').onmouseout = colorOriginal;
window.document.getElementById('costosemanal').onclick = function(){
calculareserva(7, 155);
}
}
function mensaje(){
alert('Manejador semántico con ID');
}
function cambioColor(){
window.document.body.bgColor = '#000';
}
function colorOriginal(){
window.document.body.bgColor = '#fff';
}
/* Función nombrada sin argumentos */
function valorareserva(){
var costosemana;
costosemana= parseInt(7 * 155);
alert('Función nombrada sin parámetros: valorareserva. El costo de la estadía es de $' + costosemana);
}
/* Función nombrada con argumentos */
function calculareserva(dias, costoxdia){
var costosemana;
costosemana= parseInt(dias * costoxdia);
alert('Función nombrada con argumentos: calculareserva. El costo de la estadía es de $' + costosemana);
}
</script>
</head>
<body>
<div id="menu">
<ul>
<li class="elementomenu"><a href="#" id="msId"><span>Inicio</span></a></li>
<li class="subelemento"><a href="#"><span>Complejo</span></a>
<ul>
<li class="subelemento"><a href="#"><span>Presupuestos</span></a>
<ul>
<!-- Ejemplo: código javascript asociado a una etiqueta.-->
<li><a href="javascript: alert('Sin función, código directo. El costo de la estadía es de $' + (7 * 155));"><span>Calcular costo reserva por 7 días</span></a></li>
<!-- Ejemplo: función nombrada sin parámetros asociada a un manejador de eventos de etiqueta.
<li><a href="javascript: valorareserva();"><span>Calcular costo reserva por 7 días</span></a></li>-->
<!-- Ejemplo: función nombrada con parámetros asociada a un manejador de eventos de etiqueta.
<li><a href="javascript: calculareserva(7, 155);"><span>Calcular costo reserva por 7 días</span></a></li>-->
<!-- Ejemplo: función anónima con parámetros asociada a un manejador de eventos semántico.
<li><a href="#" id="costosemanal"><span>Calcular costo estadía por 7 días</span></a></li>-->
<li><a href="#"><span>Calcular días de descuento</span></a></li>
</ul>
</li>
<li class="subelemento"><a href="#"><span>Servicios</span></a>
<ul>
<li><a href="#"><span>Desayuno Americano</span></a></li>
<li><a href="#"><span>Spa</span></a></li>
</ul>
</li>
</ul>
</li>
<li><a href="#"><span>Reservas</span></a></li>
<li><a href="#" id="ImgMsId"><span>Contacto</span></a></li>
</ul>
</div>
</body>
</html>