Javascript-форум (https://javascript.ru/forum/)
-   Элементы интерфейса (https://javascript.ru/forum/dom-window/)
-   -   Вылеление активных пунков меню. Нужна помощь ! (https://javascript.ru/forum/dom-window/29883-vylelenie-aktivnykh-punkov-menyu-nuzhna-pomoshh.html)

panictmn 15.07.2012 17:17

Вылеление активных пунков меню. Нужна помощь !
 
Добрый день !
Cразу скажу что с программированием я на вы также и с JAVA. Такчто сильно не пинайте)

Ситуация следующая:
потребовалось сделать выделение активных пунков меню на сайте,
я добавил в меню ****.тпл ява скрипт который смотрит в div id="ttt" все ссылки и сверяет с адресом текущей страницы и если адрес совпадает с какой то ссылкой, то этой ссылке присваивается class="left_menu_selected" и ссылка начинает использовать этот класс из css'ок... вот собственно и весь процесс...

сам скрипт:
<script type="text/javascript">
$.each($("#ttt a"), function(){if(this.href == location.href.split('?')[0].split('#')[0]) this.className = "left_menu_selected";});
</script>


все работает, но проблемма вылезла следующая:
помимо основного меню (которое вверху страницы) существует еще боковое подменю, когда открываем ссылку с бокового, то выделение верхнего меню пропадает.., конечно оно пропадает из-за того, что активная ссылка(адресс открытой страницы) изменяется. Ну а боковая ссылка выделяется как положено...

Я понимаю, что все решила бы жетская привязка выделения пункта меню к нескольким ссылкам, сайт нетакой большой, и руками это приписать не составит труда, вопрос только как заставить скрипт сверять ссылку пункта меню с несколькими (зараенее прописаными) ссылками?

Deff 15.07.2012 17:57

<script type="text/javascript">
$(document).ready(function(){
  var TstLink = document.url.split('?')[0].split('#')[0];
  $("body a").each( function(){
      if($(this).attr("href") == TstLink) $(this).addclass("left_menu_selected");
  });
}); 
</script>

Deff 15.07.2012 19:01

Цитата:

Сообщение от panictmn
вопрос только как заставить скрипт сверять ссылку пункта меню с несколькими (зараенее прописаными) ссылками?

Ну мон заранее заполнить атрибут data="['Lonk1','Lonk2','Lonk3']" в ссылке

И
var TstLink = document.url.split('?')[0].split('#')[0]
$("body a[data]").each( function(){
   Flag=false;
   var a_Array= eval($(this).attr("data"));
for(var i in  a_Array){
  if(TstLink==a_Array[i]){Flag=true;break;}
}
  if(Flag) $(this).addclass("left_menu_selected")
});

aults 17.07.2012 02:22

Deff, помогите пожалуйста... у меня такая же проблема с меню и у меня не получается использовать ваш код...
у меня есть 2 меню вида
<div id="123">
<ul>
         <li><a href="1">1<a/></li>
         <li><a href="2">2<a/></li>
      </ul>
</div>

<div id="456">
<ul>
         <li><a href="11">1.1<a/></li>
         <li><a href="22">2.2<a/></li>
      </ul>
</div>

и я хочу объединить (выделить) ссылки 1 и 1.1
добавляю ссылкам атрибут data="['Lonk1']"
и ниже ставлю ваш код
<script type="text/javascript">
var TstLink = document.url.split('?')[0].split('#')[0]
$("body a[data]").each( function(){
   Flag=false;
   var a_Array= eval($(this).attr("data"));
for(var i in  a_Array){
  if(TstLink==a_Array[i]){Flag=true;break;}
}
  if(Flag) $(this).addclass("left_menu_selected")
});
</script>

но класс ссылкам не добавляется...
что я делаю не так?
если вас не затруднит, покажите как вся конструкция должна выглядеть в html варианте...
заранее спасибо!

Deff 17.07.2012 02:46

aults,
Поясните задачку полностью, для сверки единственного линка по ссылке - этих финтов не нужно
<div id="123">
<ul>
         <li><a href="1">1<a/></li>
         <li><a href="2">2<a/></li>
      </ul>
</div>

<div id="456">
<ul>
         <li><a href="11">1.1<a/></li>
         <li><a href="22">2.2<a/></li>
      </ul>
</div>



<script type="text/javascript">
var TstLink = document.url;
$("div[id] > ul > a").each( function(){
  if(TstLink==this.href)$(this).addclass("left_menu_selected");
});
</script>

aults 17.07.2012 09:31

Deff,
задача и проблема аналогична первому посту

Deff 17.07.2012 11:11

Цитата:

Сообщение от aults
задача и проблема аналогична первому посту

Лучше повторите собственную версию, - мож второй раз и решение будет чётче

aults 17.07.2012 12:55

Цитата:

Сообщение от Deff (Сообщение 189452)
Лучше повторите собственную версию, - мож второй раз и решение будет чётче

в каком смысле четче? я пробовал уже по всякому но не работает, покажите как оно должно выглядеть в хтмл документе пожалуйста...

Deff 17.07.2012 13:05

Цитата:

Сообщение от Deff
Лучше повторите собственную версию,

Задачи!

aults 17.07.2012 13:21

Deff,
дак все то же самое и скрипт изначально я тот же использую
<script type="text/javascript">
$.each($("#ttt a"), function(){if(this.href == location.href.split('?')[0].split('#')[0]) this.className = "left_menu_selected";});
</script>

но не могу присвоить класс ссылке основной страницы, если открыта дополнительная...

Deff 17.07.2012 13:35

aults,
Выложите Ваш код попыток - мну поправит

aults 17.07.2012 14:34

Deff,
я хочу сделать так же как тут - при переходе на http://www.null.ru/services/ выделена только ссылка услуги (текущая страница)...
а при переходе на http://www.null.ru/services/graphics/ выделены 2 ссылки "услуги" и "графика"
у меня получилось выделить только текущую страницу этим кодом
<script type="text/javascript">
$.each($("#ttt a"), function(){if(this.href == location.href.split('?')[0].split('#')[0]) this.className = "left_menu_selected";});
</script>

как выделить ссылку на текущую страницу и страницу выше уровнем находясь на дополнительной, но при этом не выделять ссылку на доп страницу, если открыта страница верхнего уровня? как то так...

код попытки я же уже приводил выше...

Deff 17.07.2012 14:56

aults,
ясно -> http://www.null.ru/services/graphics/ *вышеприведенный код был несколько для иного

Deff 17.07.2012 15:07

aults,
Вопроса:
Приведите вид для пары ссылок в атрибуте href=" выделяемой ссылки

aults 17.07.2012 17:19

Deff,
<a href="/usludi_po_ozeleneniyu.html">Услуги по озеленению<a/>
<a href="/usloviya.html">Условия<a/>
<a href="/ceny.html">Цены<a/>

Deff 17.07.2012 18:29

aults,
Зы - тады непонятно опять

На указанном Вами форуме ссылки выделяются по принципу наличия вхождения -> http://www.null.ru/services/graphics/ как конечной папки так и хотя бы родительской
Ваши ссылки пока никак не связаны
У топик стартера осуществлялся поиск на странице по коду в якоре ( вида #aaaa,#bbbb прикрепляемых к текущей ссылке
================================================
Т.е пока неясен главный Вопрос - какие ссылки уВас на странице подлежат Выделению

aults 17.07.2012 19:05

<a href="/usludi_po_ozeleneniyu.html">Услуги по озеленению<a/> - основная
<a href="/usloviya.html">Условия<a/> - дополнительная
<a href="/ceny.html">Цены<a/> - дополнительная
я же сразу сказал что у меня так же как и у тса и даже скрипт используется тот же самый что и у него...

Deff 17.07.2012 19:22

aults,
Чел, чтобы идентифицировать нужные ссылки к адресу приклеивает
href://aдрес?a=чтот-то#некий идентификатор

Вот его(идентификатор) в Data ccылок и ищем

aults 17.07.2012 19:42

скрипт я взял отсюда http://helper.ucoz.ru/load/all/ochen...sylki/1-1-0-60 и тс скорее всего тоже... и он просто сканирует блок ссылок и выделяет ссылку страницы открытой в данный момент... и никаких идентификаторов... поэтому и снимается выделение с основной при переходе на дополнительную т.к. урл уже другой... а надо чтоб не снималось... как сделать чтобы не снималось? простой пример хтмл кода и прошу, потому что не получается у меня разобраться...

Deff 17.07.2012 19:45

aults,
Рисуйте Ваше меню - иначе я не врублюсь (где главная - не главная - помечайте

aults 17.07.2012 19:56

Deff,
вот вся конструкция в данный момент
<div id="ttt">
<ul>
<a href="/usludi_po_ozeleneniyu.html">Услуги по озеленению<a/> - основная
<a href="/usloviya.html">Условия<a/> - дополнительная
<a href="/ceny.html">Цены<a/> - дополнительная
</ul>
</div>


<script type="text/javascript">
$.each($("#ttt a"), function(){if(this.href == location.href.split('?')[0].split('#')[0]) this.className = "left_menu_selected";});
</script>

Deff 17.07.2012 20:00

aults,
Т. е если совпала - хоть одна ссылка с ссылкой в Адресной строке - нам нужно поставить выделения на все ссылки выше данной, включая и её саму ?

aults 17.07.2012 20:04

Deff,
да

Deff 17.07.2012 20:40

<script type="text/javascript" src="http://yandex.st/jquery/1.4.4/jquery.min.js"></script>
<style type="text/css">
#ttt a.active {
 color:red!important;
}
</style>


<div id="ttt">
<ul>
<a href="/usludi_po_ozeleneniyu.html">Услуги по озеленению</a> - основная<br />
<a href="/usloviya.html">Условия</a> - дополнительная<br />
<a href="/ceny.html">Цены</a> - дополнительная<br />
</ul>
</div>

<script type="text/javascript">
var TstLink =location.href.split('?')[0].split('#')[0].replace(/^.*[^\/]\//g,'/');
var TstLink = "/usloviya.html" //Тестовая строка -только для теста, затем убрать

$("#ttt ul a").each(function(){
  if($(this).attr('href').indexOf(TstLink)!=-1){
   var Arr_a=$(this).parent().find('a');
   var Cickl=Arr_a.index(this);
     for(var i=0; i<=Cickl; i++){
       Arr_a.eq(i).addClass('active')
     }
  }
});
</script>

aults 18.07.2012 00:48

Deff,
хорошо, а по какому принципу скрипт определяет главную (верхнюю) ссылку

Deff 18.07.2012 00:52

aults,
Он находит текущую ссылку, - далее смотрит её индекс в массиве ссылок родительского блока - далее проставляет class=active от 0(это и есть первая ссылка до текущего индекса(включая его)
Текущий индекс = это Cickl)

panictmn 24.07.2012 09:29

Deff,
Почитал вашу переписку с Aults, заданый вопрос решился..., спасибо вам!
но возник другой:
теперь таже проблемма с боковым меню:
[xfgiven_leftcol]
                <div id="ttt">
		<div class="LeftCol ">
			<ul class="left_menu">
[xfgiven_name1]
				<li>
<a href="[xfvalue_link1]" target="">[xfvalue_name1]</a>
				</li>
[/xfgiven_name1]
[xfgiven_name2]
				<li>
<a href="[xfvalue_link2]" target="">[xfvalue_name2]</a>
				</li>
[/xfgiven_name2]
[xfgiven_name3]
				<li>
<a href="[xfvalue_link3]" target="">[xfvalue_name3]</a>
				</li>
[/xfgiven_name3]
[xfgiven_name4]
				<li>
<a href="[xfvalue_link4]" target="">[xfvalue_name4]</a>
				</li>
[/xfgiven_name4]
		</ul>			
		</div>
	</div>	
<script type="text/javascript">
$.each($("#ttt a"), function(){if(this.href == location.href.split('?')[0].split('#')[0]) this.className = "left_menu_selected";});
</script>
	<div class="container WithoutRightCol">
	<div class="content ">
[/xfgiven_leftcol]


Здесь выделение ссылки опять же пропадает при смене текущей ссылки (например при пролистывании страницы) тоесть изначально page1, - ссылка выделена, когда она становится page2 - выделение пропало.

как всетаки прописать скрипту четкие ссылки при открытии которых надо "держать" выделение пункта меню ?

a-key 22.01.2014 12:18

Здравствуйте, форумчане!
 
Как выделить несколько активных ссылок?
Пример - текущий url /service/design
надо выделить ссылку /service
также ссылка /service/design должна подсвечиваться...
Я так предполагаю не надо сравнивать url и href, а искать совпадения, но как?


Часовой пояс GMT +3, время: 07:20.