
Exemplo de uma barra de navegação onde foi usado o behavior Rollover Image. Realizado por Eduardo Rodrigues para o site zoom.pt.
A partir do menu insert do Dreamweaver podemos inserir / criar menus de navegação. Obviamente esta não é a única forma de os criar, mas é, certamente, uma forma prática de os inserir num projecto. Vejamos dois exemplos, um com rollover image, outro com o navigation bar. Em ambos os exemlos o javascript é gerado automaticamente pelo Dreamweaver.
A de inserção de rollover image é simples podendo em poucas etapas obtermos uma barra de navegação atractiva e eficaz.
O primeiro passo consiste em criar duas imagens para o botão de navegação: uma para o estado do botão antes da interacção, outra para o momento em que passamos o cursor sobre o botão. Depois das imagens criadas e guardadas no directório do site seguimos os seguintes passos:
1- No menu insert, tab common, abrir o menu dropdown e clicar em rollover image;

2- No popup aberto, só temos que dar um nome à imagem, escolher a imagem original e a imagem e a imagem que aparece quando passamos o cursor. Por uma questão de velocidade de refrescamento da página devemos seleccionar a opção Preload rollover image. Igualmente devemos escolher o alt para a imagem e, por último, definir a página a abrir quando clicamos no botão em When Clicked go to URL.

Quando realizamos estes passos o javascript necessário é automaticamente gerado e incluído na head do documento.
<script type="text/javascript">
<!--
function MM_swapImgRestore() { //v3.0
var i,x,a=document.MM_sr; for(i=0;a&&i<a.length&&(x=a[i])&&x.oSrc;i++) x.src=x.oSrc;
}
function MM_preloadImages() { //v3.0
var d=document; if(d.images){ if(!d.MM_p) d.MM_p=new Array();
var i,j=d.MM_p.length,a=MM_preloadImages.arguments; for(i=0; i<a.length; i++)
if (a[i].indexOf("#")!=0){ d.MM_p[j]=new Image; d.MM_p[j++].src=a[i];}}
}
function MM_findObj(n, d) { //v4.01
var p,i,x; if(!d) d=document; if((p=n.indexOf("?"))>0&&parent.frames.length) {
d=parent.frames[n.substring(p+1)].document; n=n.substring(0,p);}
if(!(x=d[n])&&d.all) x=d.all[n]; for (i=0;!x&&i<d.forms.length;i++) x=d.forms[i][n];
for(i=0;!x&&d.layers&&i<d.layers.length;i++) x=MM_findObj(n,d.layers[i].document);
if(!x && d.getElementById) x=d.getElementById(n); return x;
}
function MM_swapImage() { //v3.0
var i,j=0,x,a=MM_swapImage.arguments; document.MM_sr=new Array; for(i=0;i<(a.length-2);i+=3)
if ((x=MM_findObj(a[i]))!=null){document.MM_sr[j++]=x; if(!x.oSrc) x.oSrc=x.src; x.src=a[i+2];}
}
//-->
</script>
No ínício do body é gerado o script que permite o pré-carregamento (preload) das imagens.
<body onload="MM_preloadImages('imagens/Picture 5.png')">
<a href="index.html" onmouseout="MM_swapImgRestore()" onmouseover="MM_swapImage('Image1','','imagens/Picture 5.png',1)"><img src="imagens/Picture 1.png" alt="pppp" name="Image1" width="458" height="217" border="0" id="Image1" /></a>
A par do rollover image o menu navigation bar é de simples realização. Para a sua concretização, depois de criadas as imagens, basta seguirmos os seguintes passos:
1- No menu insert, tab common, abrir o menu dropdown e clicar em Navigation Bar;

2 - No popup aberto podemos verificar que não existem diferenças consideráveis relativamente ao rollover image. Neste painel podemos definir o nome dos botões da barra de navegação e decidir quatro estados do botão: up, over, down e over while down, ou seja, a imagem sem interacção (up), quando passamo o cursor por cima (over), quando clicamos ( down) e enquanto mantê-mos o ciursor por cima do botão depois de clicado(over whle down). Geralmente só precisamos de dois estados (up e over) portanto, o mesmo número de imagens do botão rollover image do exemplo anterior.
Escolhemos o texto alternativo para cada imagem, seleccioná-mos a opção de preload images e definimos a página de destino em when clicked go to URL.
Podemos, também, decidir se queremos inserir a barra de navegação na horizontal ou na vertical.

O javascript é automaticamente gerado e incluido na head do documento.
<script type="text/javascript">
<!--
function MM_preloadImages() { //v3.0
var d=document; if(d.images){ if(!d.MM_p) d.MM_p=new Array();
var i,j=d.MM_p.length,a=MM_preloadImages.arguments; for(i=0; i<a.length; i++)
if (a[i].indexOf("#")!=0){ d.MM_p[j]=new Image; d.MM_p[j++].src=a[i];}}
}
function MM_findObj(n, d) { //v4.01
var p,i,x; if(!d) d=document; if((p=n.indexOf("?"))>0&&parent.frames.length) {
d=parent.frames[n.substring(p+1)].document; n=n.substring(0,p);}
if(!(x=d[n])&&d.all) x=d.all[n]; for (i=0;!x&&i<d.forms.length;i++) x=d.forms[i][n];
for(i=0;!x&&d.layers&&i<d.layers.length;i++) x=MM_findObj(n,d.layers[i].document);
if(!x && d.getElementById) x=d.getElementById(n); return x;
}
function MM_nbGroup(event, grpName) { //v6.0
var i,img,nbArr,args=MM_nbGroup.arguments;
if (event == "init" && args.length > 2) {
if ((img = MM_findObj(args[2])) != null && !img.MM_init) {
img.MM_init = true; img.MM_up = args[3]; img.MM_dn = img.src;
if ((nbArr = document[grpName]) == null) nbArr = document[grpName] = new Array();
nbArr[nbArr.length] = img;
for (i=4; i < args.length-1; i+=2) if ((img = MM_findObj(args[i])) != null) {
if (!img.MM_up) img.MM_up = img.src;
img.src = img.MM_dn = args[i+1];
nbArr[nbArr.length] = img;
} }
} else if (event == "over") {
document.MM_nbOver = nbArr = new Array();
for (i=1; i < args.length-1; i+=3) if ((img = MM_findObj(args[i])) != null) {
if (!img.MM_up) img.MM_up = img.src;
img.src = (img.MM_dn && args[i+2]) ? args[i+2] : ((args[i+1])? args[i+1] : img.MM_up);
nbArr[nbArr.length] = img;
}
} else if (event == "out" ) {
for (i=0; i < document.MM_nbOver.length; i++) {
img = document.MM_nbOver[i]; img.src = (img.MM_dn) ? img.MM_dn : img.MM_up; }
} else if (event == "down") {
nbArr = document[grpName];
if (nbArr)
for (i=0; i < nbArr.length; i++) { img=nbArr[i]; img.src = img.MM_up; img.MM_dn = 0; }
document[grpName] = nbArr = new Array();
for (i=2; i < args.length-1; i+=2) if ((img = MM_findObj(args[i])) != null) {
if (!img.MM_up) img.MM_up = img.src;
img.src = img.MM_dn = (args[i+1])? args[i+1] : img.MM_up;
nbArr[nbArr.length] = img;
} }
}
//-->
</script>
E no corpo do documento foi criado o script de preload das imagens e um menu inserido dentro de uma tabela.
<body onload="MM_preloadImages('imagens/rollover1.jpg','imagens/rollover2.jpg')">
<table border="0" cellpadding="0" cellspacing="0">
<tr>
<td><a href="index2.html" target="_top" onclick="MM_nbGroup('down','group1','inicio','',1)" onmouseover="MM_nbGroup('over','inicio','imagens/rollover1.jpg','',1)" onmouseout="MM_nbGroup('out')"><img src="imagens/navbar0.jpg" alt="" name="inicio" width="290" height="222" border="0" id="inicio" onload="" /></a></td>
<td><a href="index.html" target="_top" onclick="MM_nbGroup('down','group1','fim','',1)" onmouseover="MM_nbGroup('over','fim','imagens/rollover2.jpg','',1)" onmouseout="MM_nbGroup('out')"><img src="imagens/navbar1.jpg" alt="" name="fim" width="516" height="361" border="0" id="fim" onload="" /></a></td>
</tr>
</table>