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 :: Скрипты и радиокнопки

 PHP.SU

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


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

> Без описания
Aricus
Отправлено: 19 Января, 2015 - 05:57:21
Post Id



Частый гость


Покинул форум
Сообщений всего: 245
Дата рег-ции: Апр. 2014  


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




Я хочу, чтобы при выборе радиокнопки
CODE (html):
скопировать код в буфер обмена
  1. <input type="radio" name="ansStatus" value="0" checked="checked" /> <span class="textGreen"> Ответ </span> <input type="radio" name="ansStatus" value="-1" /> <span class="textBlue"> Комментарий </span>

цвет textarea менялся на зелёный или синий, в зависимости от значения. Для этого я написал такой скрпит:
CODE (javascript):
скопировать код в буфер обмена
  1. $('input[name="ansStatus"]').on("click", function(){
  2.         if (this.value == '-1') $("#askDescription").class = "TAgreen";
  3.                 else {if (this.value == '0') $("#askDescription").class = "TAblue";}
  4. return false;  
  5. });

Но он не только не работает (то есть цвет поля не меняется), но при щелчке на второй кнопке происходит баг с самими кнопками: они обе становятся не выделенными (при отключении скрипта баг исчезает).
В чём ошибка?
 
 Top
skiphog
Отправлено: 19 Января, 2015 - 09:07:29
Post Id



Частый гость


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


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




CODE (javascript):
скопировать код в буфер обмена
  1. $("#askDescription").class = "TAblue" //Синтаксис неверный


Для добавления/удаления классов в jQuery есть
CODE (javascript):
скопировать код в буфер обмена
  1. $("#askDescription").addClass('имя класса');
  2. // или
  3. $("#askDescription").removeClass('имя класса');

Можно сделать без jQuery
CODE (javascript):
скопировать код в буфер обмена
  1. document.getElementById('askDescription').className = 'Имя класса';

В вашем случае, если проверка простая, только на ВКЛ/ВЫКЛ, посмотрите в сторону toggleClass('имя класса');
CODE (javascript):
скопировать код в буфер обмена
  1. $('input[name="ansStatus"]').on("click", function(){
  2.   $("#askDescription").toggleClass("Имя класса");
  3.   //По клику, класс сам будет добавляться/удаляться.  
  4. });

P.S. Если конструкцию $('') используете больше, чем один раз, закешируйте результат $('') в переменную, а потом играйтесь, как хотите Улыбка
 
My status
 Top
Dastor
Отправлено: 19 Января, 2015 - 10:26:30
Post Id


Гость


Покинул форум
Сообщений всего: 66
Дата рег-ции: Окт. 2014  


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




Можно, кстати, и без JS Улыбка
Может кому пригодится

CODE (html):
скопировать код в буфер обмена
  1. <!DOCTYPE HTML>
  2. <html>
  3.   <head>
  4.   <meta charset="utf-8">
  5.   <style>
  6.     #green:checked ~ .desc > #askDescription {
  7.       background-color: green;
  8.     }
  9.     #blue:checked ~ .desc > #askDescription {
  10.       background-color: blue;
  11.     }
  12.    </style>
  13.   </head>
  14.   <body>
  15.     <input id="green" type="radio" name="ansStatus" checked="checked">
  16.     <input id="blue" type="radio" name="ansStatus">
  17.     <div class="desc">
  18.       <input id="askDescription" type="textarea" name="askDescription">
  19.     </div>
  20.   </body>
  21. </html>
 
 Top
Aricus
Отправлено: 20 Января, 2015 - 18:36:46
Post Id



Частый гость


Покинул форум
Сообщений всего: 245
Дата рег-ции: Апр. 2014  


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




вопрос снят
Если кому интересно, нужно ещё было убрать return false;
CODE (javascript):
скопировать код в буфер обмена
  1. $('input[name="ansStatus"]').on("click", function(){
  2.         if (this.value == '-1') document.getElementById('askDescription').className = "TAblue";
  3.                 else {if (this.value == '0') document.getElementById('askDescription').className = "TAgreen";} 
  4. });

(Отредактировано автором: 20 Января, 2015 - 18:46:04)

 
 Top
Страниц (1): [1]
Сейчас эту тему просматривают: 0 (гостей: 0, зарегистрированных: 0)
« JavaScript & VBScript »


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



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

 
Powered by ExBB FM 1.0 RC1. InvisionExBB