Estou implementando um menu fancy em java + css que peguei na internet e ele já esta quase 100%. O unico problema é que ao clicar nos itens do menu que deveriam abrir links em um target ele simplesmente não faz nada.
Acho que o problema esta no javascript no event click.
Desejo que o link seja aberto ao clicar. Abaixo segue o HTML e o JAVA.
Pergunta
BananaRJ
Estou implementando um menu fancy em java + css que peguei na internet e ele já esta quase 100%. O unico problema é que ao clicar nos itens do menu que deveriam abrir links em um target ele simplesmente não faz nada.
Acho que o problema esta no javascript no event click.
Desejo que o link seja aberto ao clicar. Abaixo segue o HTML e o JAVA.
>HTML:
<div id="fancymenu" align="center"> <ul> <li class="current" id="menu_home"><a href="home.htm" target="bottomFrame">Home</a></li> <li id="menu_servicos"><a href="servicos.htm" target="bottomFrame">Servicos</a></li> <li id="menu_clientes"><a href="clientes.htm" target="bottomFrame">Clientes</a></li> <li id="menu_contato"><a href="contato.htm" target="bottomFrame">Contato</a></li> <li class="background"> <div class="left"> </div> </li> </ul> </div>>java script:var SlideList = new Class({ initialize: function(menu, options) { this.setOptions(this.getOptions(), options); this.menu = $(menu), this.current = this.menu.getElement('li.current'); this.menu.getElements('li').each(function(item){ item.addEvent('mouseover', function(){ this.moveBg(item); }.bind(this)); item.addEvent('mouseout', function(){ this.moveBg(this.current); }.bind(this)); item.addEvent('click', function(event){ this.clickItem(event, item); }.bind(this)); }.bind(this)); this.back = new Element('li').addClass('background').adopt(new Element('div').addClass('left')).injectInside(this.menu); this.back.fx = this.back.effects(this.options); if(this.current) this.setCurrent(this.current); }, setCurrent: function(el, effect){ this.back.setStyles({left: (el.offsetLeft)+'px', width: (el.offsetWidth)+'px'}); (effect) ? this.back.effect('opacity').set(0).start(1) : this.back.setOpacity(1); this.current = el; }, getOptions: function(){ return { transition: Fx.Transitions.sineInOut, duration: 700, wait: false, onClick: Class.empty }; }, clickItem: function(event, item) { if(!this.current) this.setCurrent(item, true); this.current = item; this.options.onClick(new Event(event), item); }, moveBg: function(to) { if(!this.current) return; this.back.fx.custom({ left: [this.back.offsetLeft, to.offsetLeft], width: [this.back.offsetWidth, to.offsetWidth] }); } }); SlideList.implement(new Options); window.addEvent('domready', function() { new SlideList($E('ul', 'fancymenu'), {transition: Fx.Transitions.backOut, duration: 700, onClick: function(ev, item) { ev.stop(); }}); });Editado por andreia_spUtilize tags para código, facilitam a visualização. Andreia_Sp
Link para o comentário
Compartilhar em outros sites
4 respostass a esta questão
Posts Recomendados
Participe da discussão
Você pode postar agora e se registrar depois. Se você já tem uma conta, acesse agora para postar com sua conta.