Warning: Cannot use a scalar value as an array in /home/admin/public_html/forum/include/fm.class.php on line 757

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/include/fm.class.php on line 770

Warning: Invalid argument supplied for foreach() in /home/admin/public_html/forum/topic.php on line 737
Форумы портала PHP.SU :: Show / Hide

 PHP.SU

Программирование на PHP, MySQL и другие веб-технологии
PHP.SU Портал     На главную страницу форума Главная     Помощь Помощь     Поиск Поиск     Поиск Яндекс Поиск Яндекс     Вакансии  Пользователи Пользователи


 Страниц (1): [1]   

> Без описания
4ik
Отправлено: 18 Ноября, 2012 - 23:16:16
Post Id


Гость


Покинул форум
Сообщений всего: 78
Дата рег-ции: Июнь 2011  


Помог: 0 раз(а)




Hello!

Имеется JS функция Show / Hide
CODE (javascript):
скопировать код в буфер обмена
  1.  
  2. // SHOW / HIDE
  3. function showhide(id)
  4. {
  5.         if (document.getElementById)
  6.         {
  7.                 obj = document.getElementById(id);
  8.                 if (obj.style.display == "none")
  9.                 {
  10.                         obj.style.display = "";
  11.                 }
  12.  
  13.                 else
  14.  
  15.                 {
  16.                         obj.style.display = "none";
  17.                 }
  18.         }
  19. }
  20.  


Вызываю на странице так:
CODE (html):
скопировать код в буфер обмена
  1.  
  2. <a onclick="showhide('menu');" href="javascript:;">Menu infa</a>
  3.  
  4. <div id="menu" style="display: none;">Infa 1</div>
  5. <div id="menu" style="display: none;">Infa 2</div>
  6.  


Соль в том что на странице будет два Div'a с результатом (один ID) а тображается только в первом.

(Отредактировано автором: 18 Ноября, 2012 - 23:26:17)

 
 Top
OrmaJever
Отправлено: 18 Ноября, 2012 - 23:28:06
Post Id



Активный участник


Покинул форум
Сообщений всего: 7540
Дата рег-ции: Янв. 2010  
Откуда: Чернигов


Помог: 299 раз(а)




Во-первых интереснейшая проверка
CODE (javascript):
скопировать код в буфер обмена
  1. if (document.getElementById)

Что она проверяет?
Во-вторых вас не смушает что по стандартам на странице дожен быть тоько один уникаьный id у эемента, а у вас их как бы два.


-----
Если вы хотя бы 3-4 раза не решите всё выкинуть и начать заново - вы явно что-то делаете не так.
 
 Top
4ik
Отправлено: 18 Ноября, 2012 - 23:39:30
Post Id


Гость


Покинул форум
Сообщений всего: 78
Дата рег-ции: Июнь 2011  


Помог: 0 раз(а)




Понял.
Буду искать другой способ реализации -_-
 
 Top
OrmaJever
Отправлено: 19 Ноября, 2012 - 00:14:02
Post Id



Активный участник


Покинул форум
Сообщений всего: 7540
Дата рег-ции: Янв. 2010  
Откуда: Чернигов


Помог: 299 раз(а)




Да что там думать, нужно поменять id на class, и выбирать эементы document.getElementByClassName, тоько учтите что этот метод возвращает масив, так что обращатся к еементам нужно по индексам, например document.getElementByClassName('menu')[0]


-----
Если вы хотя бы 3-4 раза не решите всё выкинуть и начать заново - вы явно что-то делаете не так.
 
 Top
AlexAnder
Отправлено: 19 Ноября, 2012 - 07:36:44
Post Id



Частый посетитель


Покинул форум
Сообщений всего: 915
Дата рег-ции: Авг. 2012  
Откуда: Россия


Помог: 34 раз(а)





CODE (html):
скопировать код в буфер обмена
  1. <a onclick="showhide('menu1');" href="javascript:">Menu infa</a>
  2. <div id="menu1" style="display: none;">Infa 1</div>
  3. <a onclick="showhide('menu2');" href="javascript:">Menu infa2</a>
  4. <div id="menu2" style="display: none;">Infa 2</div>
  5. <script>
  6. /**
  7.  * Function Show or Hide:
  8.  * Set the style display for document.getElementById(o)
  9.  * @param: id of obj
  10.  * @ver 0.0.1
  11.  */
  12. function showhide(o){
  13.   var obj = document.getElementById(o);
  14.   obj.style.display = (obj.style.display == 'none') ? 'block' : 'none';
  15. }
  16. </script>


-----
Оказывается, недостаточно читать справочники, чтобы правильно писать коды. sadex ©

Форумы стали местом обучения программированию, а не решения трудных вопросов. KingStar ©
 
 Top
esterio
Отправлено: 19 Ноября, 2012 - 17:27:07
Post Id



Активный участник


Покинул форум
Сообщений всего: 5025
Дата рег-ции: Нояб. 2012  
Откуда: Украина, Львов


Помог: 127 раз(а)




1.
http://javascript[dot]ru/ui/show-hide-toggle
Статья "Правильные show/hide/toggle"

2.
должен бить только 1 ІД на странице. getElementById возвращает первый найденый елемент

3.
Используйте jQuery

CODE (javascript):
скопировать код в буфер обмена
  1. function showhide(name)
  2. {
  3.         $('.' + name).toogle();
  4. }


CODE (html):
скопировать код в буфер обмена
  1. <a href="#" onclick="showhide('menu'); return false;">Menu infa</a>
  2.  
  3. <div class="menu" style="display: none;">Infa 1</div>
  4. <div class="menu" style="display: none;">Infa 2</div>


не забуть подключить jQuery
 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« Напишите за меня, пожалуйста »


Все гости форума могут просматривать этот раздел.
Только зарегистрированные пользователи могут создавать новые темы в этом разделе.
Только зарегистрированные пользователи могут отвечать на сообщения в этом разделе.
 



Powered by PHP  Powered By MySQL  Powered by Nginx  Valid CSS  RSS

 
Powered by ExBB FM 1.0 RC1. InvisionExBB