Вход

Просмотр полной версии : Добавить активный элемент


Wirty
08.08.2009, 19:19
Делаю меню для сайта такой конструкции:
<div id="Menu">
<ul>
<li class="button1"><a href="#">Кнопка</a></li>
<li class="button2"><a href="#">Кнопка</a></li>
<li class="button3"><a href="#">Кнопка</a></li>
<li class="button4"><a href="#">Кнопка</a></li>
<li class="button5"><a href="#">Кнопка</a></li>
</ul>
</div>

Дальше пишу скрипт:

var arr = [ "button1 > a", "button2 > a", "button3 > a", "button4 > a", "button5 > a" ];
jQuery.each(arr, function(i) {
$("." + arr[i]).mouseenter(function () {
$("." + arr[i]).stop();
$("." + arr[i]).animate({width:"240px"}, 500);
});
$("." + arr[i]).mouseleave(function () {
$("." + arr[i]).stop();
$("." + arr[i]).animate({width:"45px"}, 500);
});
$("." + arr[i]).click(function () {
$("." + arr[i]).css("width","240px");
$("." + arr[i]).mouseleave(function () {
$("." + arr[i]).stop();});
});
});

Эффекты работают как надо, но только не знаю каким образом добавить активный элемент. Например, если посетитель находиться на главной, активный элемент (в данном случае имеющий width:240px) button1 > a, на второй странице button2 > a и т.д.
Пробовал делать так:

$("." + arr[<?php проверка url echo int; ?>]).css("width","240px");

Но при наведении на другие элементы он не закрывался и следовательно анимация работала не в ту сторону, меню разъезжалось.
Есть подобный скрипт на MooTools:
ImageMenu (http://www.phatfusion.net/imagemenu/index.htm)

Wirty
09.08.2009, 14:47
Добавил в код следующее.

$("." + arr[<?php if (проверка) echo int;?>]).animate({width:"240px"}, 500);
$("#Menu").hover(function(){
$("." + arr[<?php if (проверка) echo int;?>]).animate({width:"45px"}, 500);
}, function(){
$("." + arr[<?php if (проверка) echo int;?>]).animate({width:"240px"}, 500);
});

Работает, но корявенько ):

Urfin
09.08.2009, 14:55
Я написал вот так:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd">
<html xmlns="http://www.w3.org/1999/xhtml"><head>
<meta http-equiv="X-UA-Compatible" content="IE=7"/>
<meta http-equiv="Content-Type" content="text/html; charset=windows-1251" />
<title>slide-menu</title>
<script src="jquery-1.3.2.min.js" type="text/javascript"></script>
<script src="jquery.hsm.js" type="text/javascript"></script>

<style type="text/css">
div#menu{width:500px; overflow:hidden;}
div#menu ul{ position:relative; list-style:none; width:1000px; height:200px; overflow:hidden; padding:0;}
div#menu ul li{ height:200px; float:left;}
div#menu ul li a{ display:block; width:98px; height:200px; border-left:2px solid #fff; float:left;}
.button1 a{background:url(images/landscapes.jpg) no-repeat;}
.button2 a{background:url(images/abstract.jpg) no-repeat;}
.button3 a{background:url(images/nature.jpg) no-repeat;}
.button4 a{background:url(images/people.jpg) no-repeat;}
.button5 a{background:url(images/urban.jpg) no-repeat;}
.active a{width:310px;}
</style>
</head><body>
<div id="menu">
<ul>
<li class="button1"><a href="#"></a></li>
<li class="button2"><a href="#"></a></li>
<li class="button3"><a href="#"></a></li>
<li class="button4"><a href="#"></a></li>
<li class="button5"><a href="#"></a></li>
</ul>
</div>
</body>
</html>

// JavaScript Document jquery.hsm.js

$(document).ready(function() {
$('#menu').find('a').mouseenter(
function(){
$('#menu').find('a').stop(true,false);
$(this).animate({'width':'310px'});
$(this).parent('li').siblings('li').find('a').anim ate({'width':'45px'});
}).live('click',function(){
$(this).animate({'width':'310px'});
$(this).parent('li').siblings('li').find('a').anim ate({'width':'45px'}).end().removeClass('active'). end().addClass('active');
if($('#menu').find('li').hasClass('active')){
$('#menu').mouseleave(
function(){
$(this).find('a').stop(true,false);
$(this).find('li:not(.active)').find('a').animate( {'width':'45px'});
$(this).find('li.active').find('a').animate({'widt h':'310px'});
}
);
}
});
if(!($('#menu').find('li').hasClass('active'))){
$('#menu').mouseleave(
function(){
$(this).find('a').stop(true,false);
$(this).find('a').animate({'width':'98px'});
}
);
}
else{
$('#menu').mouseleave(
function(){
$(this).find('a').stop(true,false);
$(this).find('li:not(.active)').find('a').animate( {'width':'45px'});
$(this).find('li.active').find('a').animate({'widt h':'310px'});
}
);
}
});

Wirty
09.08.2009, 15:34
Да, у вас анимация почетче работает ))). А как добавить активный элемент при загрузке странице по определенной ссылке? Будет ли работать такой код:

$("#menu > a"[<?php ставлю индекс в зависимости от url ?>])....


Добавил:

$('.<?php ?> > a').animate({'width':'240px'});
$('.<?php ?> > a').parent('li').siblings('li').find('a').animate( {'width':'45px'}).end().removeClass('active').end( ).addClass('active');

Urfin
09.08.2009, 16:04
Нужно просто тегу <li> с ссылкой на текущую страницу добавлять класс active лучше средствами php конечно.

Wirty
09.08.2009, 16:06
Спасибо большое, разобрался.